在谷歌上搜索了几天后,我真的无法解决所描述的问题。希望在这里能找到解决方案。
当我在同一台服务器上调用WCF服务时,使用附加的代码。我在调用WebReq.GetRequestStream()时随机收到超时错误。
当我检查netstat时,我看到连接保持打开状态,所以可能存在问题,但我不知道如何解决它。
//request inicialization
HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create(url);
WebReq.Method = "POST";
WebReq.ContentType = "application/json; charset=utf-8";
WebReq.ContentLength = buffer.Length;
WebReq.Proxy = null;
WebReq.KeepAlive = false; //also tried with true
WebReq.AllowWriteStreamBuffering = false; //also tried with true
//this produces an error
using (Stream PostData = WebReq.GetRequestStream())
{
PostData.Write(buffer, 0, buffer.Length);
PostData.Close();
}
//open and read response
HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();
Stream Answer = WebResp.GetResponseStream();
StreamReader _Answer = new StreamReader(Answer);
WebResp.Close();
//return string
return _Answer.ReadToEnd();
大多数情况下,超时是在空闲时间达到约10秒后抛出的,但也可能在连续五个请求之后发生。真的找不到任何规律。
这段代码有什么问题?还有没有其他更好的调用WCF服务的方法?