我创建了一个基于REST的简单WCF服务,该服务在BasicHttpBinding
上运行。在我的一个web方法中,我返回一个指向JSON响应的Stream。
方法如下:
[OperationContract]
[FaultContract(typeof(ApplicationFault))]
[WebInvoke(Method = "POST", UriTemplate = "GetActiveCalls/{nurseid}")]
Stream GetActiveCalls(string nurseid);
从GetActiveCalls
的正文中,我创建了MemoryStream
的对象,并返回与响应相同的对象。代码看起来像
// Serialize the results as JSON
string jsonResult = new JavaScriptSerializer().Serialize(baseResponses);
// ContentType json
WebOperationContext.Current.OutgoingResponse.ContentType = "application/json";
WebOperationContext.Current.OutgoingResponse.Headers.Add("Cache-Control", "no-cache");
var bytes = Encoding.UTF8.GetBytes(jsonResult);
//Parse to memorystream
var ms = new MemoryStream(bytes);
ms.Seek(0, SeekOrigin.Begin);
ms.SetLength(bytes.LongLength);
return ms;
从客户端尝试此操作时,我得到的结果如
{"LastEvents":[{"FormatValues":"Klic 2 3 4","Icon":null,"Color":"Red","Acknowledged":false,"EventID":28566}],"Message":"","Status":true}
但有时在多次调用相同的方法之后,我开始得到响应:
{"LastEvents":[{"FormatValues":"Klic 2 3 4","Icon":null,"Color":"Red","Acknowledged":false,"EventID":28566}],"Message":"","Statu{"LastEv
您可以在"Statu
之后看到JSON响应,流重置并从头开始获取数据。
我觉得很奇怪。
*从服务器端,当我放置断点时,MemoryStream
似乎有正确的响应。
答案 0 :(得分:3)
暂且不考虑使用内存流的问题,我最近遇到了一个类似的问题,内存流响应似乎已经损坏,似乎是随机的。解决这个问题的方法是从web.config中删除跟踪部分,这是我在开发模式下打开的。这可能是您的问题,也可能不是,但可能值得一看。好像这个问题在.NET 4.5中仍然存在。