c# - 如何返回 Json 响应

标签 c# asp.net .net wcf

我正在尝试在我的 C# restserviceA 中实现一个方法 A,它向客户端返回一条 Json 消息。

该方法只是对内部托管服务进行另一个 restservice 调用,如下所示 ResterviceB

HttpWebRequest req = WebRequest.Create(url) as HttpWebRequest;
req.Method = "GET";
resp = req.GetResponse() as HttpWebResponse;
resp = req.GetResponse() as HttpWebResponse;
            Encoding enc = Encoding.UTF8;
            loResponseStream = new StreamReader(resp.GetResponseStream(), enc);
            string strResponse = loResponseStream.ReadToEnd();
            return resp;

此方法将从 RestServiceB 获取 json 格式的响应。我如何才能以 json 格式本身将相同的 json 字符串返回给客户端。

我尝试将如下的 webmethod 属性放入我的 methodA,但我从 RestServiceA 的 MethodA 获得的响应始终为字符串格式。

SVC接口(interface):

[OperationContract ]
[WebGet(UriTemplate = "getresults", ResponseFormat = WebMessageFormat.Json)]
String GetResults();

SVC代码

public String GetResults()
{
   string str=//Call RestServiceB which returns response as below.
   "query":"myquery", "results": [ {"name":"result1", "type":"suggest"}, {"name":"result2", "type":"type2"}]" 
    return str;
}

这里有什么建议吗?谢谢。

最佳答案

您的 JSON 字符串被包裹在另一个 JSON 字符串中。

返回原始 JSON 字符串的一种方法是将 GetResults() 的输出类型更改为 Stream 而不是字符串。

    public System.IO.Stream GetResults()
    {
       string str=//Call RestServiceB which returns response as below.
       "query":"myquery", "results": [ {"name":"result1", "type":"suggest"}, {"name":"result2", "type":"type2"}]"         
        WebOperationContext.Current.OutgoingResponse.ContentType =
        "application/json; charset=utf-8";
        return new MemoryStream(Encoding.UTF8.GetBytes(str));
    }

    [OperationContract ]
    [WebGet(UriTemplate = "getresults")]
    String GetResults();

关于c# - 如何返回 Json 响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18339069/

相关文章:

.net - ASP.NET/ADO.NET : Handling many database connections inside a . NET 对象?

c# - 如何删除 MenuStrip 控件下绘制的白线?

c# - 绑定(bind)到项目模板中的字典

c# - 四舍五入到 c# 中最接近的 10 位

html - ASP 复选框长文本未对齐

c# - 如何在c#中运行exe文件

c# - 替换 JPG 图像文件中的图像但保留元数据?

c# - 如何找到不可见的菜单项?

c# - Azure Web 角色启动时 IIS Express 失败

c# - 连接数据库时c#中的constring错误