System.Net.HttpWebRequest.GetRequestStream超时问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/LyySwx/article/details/87936806

错误

引发的异常:“System.Net.WebException”(位于 System.dll 中)
操作超时
System.Net.WebException: 操作超时
   在 System.Net.HttpWebRequest.GetResponse()
   在 tools.WebUtils.post1(String url, Byte[] fileContentByte) 位置行号 299
   在 BLL.UploadBLL.upload(String size, Byte[] fileContentByte, String Name, Int32 chunks, Int32 chunk, String filetype) 位置 行号 95
   在 Windowsupload.MainsUI.Upload(String txtFileAdress, String filesize, String filename, String sizes, Int32 iFileChunkSize, String filetype) 位置 行号 924

解决过程

用C#模拟网页登陆,其中去请求几个页面,会发起对应的http的请求request,其中keepAlive设置为true,提交请求后,然后会有对应的response: resp = (HttpWebResponse)req.GetResponse(); 之前的多次调试,一直都是可以正常获得对应的response,然后读取html页面的。 但是后来几次的调试,在没有改变代码的前提下,结果GetResponse却始终会超时死掉。

【解决过程】

1.默认request的timeout是1000000毫秒=100秒,都会超时,手动改为10秒,因此就更容易超时了,无法解决问题。

2.将http的request的keepAlive设置为false,问题依旧。

3.去参考:c# request.GetResponse();超时问题的解决,和HttpWebRequest多线程性能问题,请求超时的错误, 去把前面共4次的httprequest,每次都增加对应的: resp = null; 。。。 if (resp != null) { resp.Close(); } if (req != null) { req.Abort(); } 结果还是没解决问题。

4. 同样参考:HttpWebRequest多线程性能问题,请求超时的错误, 去尝试关于DefaultConnectionLimit的设置,改为为10: System.Net.ServicePointManager.DefaultConnectionLimit = 10; 问题依旧。

5.又去测试了下,关于response.Close() 也是没解决问题。

6. 最后无意间,索性不抱希望的,再次DefaultConnectionLimit设置为更大的值50: System.Net.ServicePointManager.DefaultConnectionLimit = 50; 试了试,结果就解决超时的问题了。
 

猜你喜欢

转载自blog.csdn.net/LyySwx/article/details/87936806