WebClient does not support concurrent I/O operations 错误的解决办法

贴出一下自己的出错代码:

 

WebClient client = new WebClient();          // 这句话应该放到for循环里.
for (int i = 0; i < mEmotionUrl.Count; i++)
 {
       string a = mEmotionUrl[i].Url;
       client.OpenReadCompleted += new OpenReadCompletedEventHandler(client_OpenReadCompleted);
       client.OpenReadAsync(new Uri(a, UriKind.RelativeOrAbsolute));
 }

 

最后,google 了半天,并看了许多资料,发现 只要错误信息含有 does not support concurrent I/O operations 信息的,都是由 一个实例同时在多个地方调用产生的,通俗易懂的说,就是并发引起的。下面摘录一句google到得解释:


I don't think you can use a single WebClient instance to execute several
HTTP requests at the same time. Try to create a WebClient instance per request,
that should work just fine.


原来自己的 client 只有一个实例引发多个调用,就报了上述错误

解决办法 :每个使用到 WebClient 的地方,都 new 一个 WebClient 实例,防止出现并发。同时 does not support concurrent I/O operations 错误的方法,一般也是由于 并发引起的,解决方法请参照上一句。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用WebClient发送HTTP请求时,可以使用multipart/form-data编码来上传文件或者发送表单数据。multipart/form-data编码是一种在HTTP传输中常用的编码方式,它可以将多个不同类型的数据(如文本、二进制文件等)一起传输到服务器。以下是一个使用WebClient发送multipart/form-data请求的示例代码: ``` using System.Net; WebClient client = new WebClient(); string url = "http://example.com/upload"; string filePath = @"C:\example.jpg"; // 设置请求头部信息 client.Headers["Content-Type"] = "multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW"; // 构造表单数据 string formData = "------WebKitFormBoundary7MA4YWxkTrZu0gW\r\n" + "Content-Disposition: form-data; name=\"file\"; filename=\"example.jpg\"\r\n" + "Content-Type: image/jpeg\r\n\r\n"; // 读取文件数据 byte[] fileData = File.ReadAllBytes(filePath); // 构造请求体 string requestContent = formData + Encoding.UTF8.GetString(fileData) + "\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW--\r\n"; // 发送请求并获取响应 byte[] responseBytes = client.UploadData(url, "POST", Encoding.UTF8.GetBytes(requestContent)); string responseString = Encoding.UTF8.GetString(responseBytes); ``` 在以上示例中,请求头部信息中指定了使用multipart/form-data编码,并设置了boundary参数。接着构造了一个表单数据,其中包括了一个文件和一个文本字段。文件数据通过读取文件内容得到,并与表单数据一起构造了请求体。最后通过调用WebClient的UploadData方法发送请求,并获取服务器的响应。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值