Проблема с WebClient.UploadData - PullRequest
2 голосов
/ 19 мая 2011

У меня есть приложение типа клиент-сервер с сервером, на котором работает HttpListener, и клиент, загружающий данные на сервер с помощью WebClient.UploadData. Код работает довольно хорошо (с большими буферами данных 60K и выше), за исключением одной установки, когда UploadData истекает, когда размер буфера данных больше 16384. Вот мой код на клиенте:

internal bool UploadData(byte[] buffer, String file, String folder)
{
    try
    {
        String uri = "http://" + GlobalData.ServerIP + ":" + GlobalData.ServerHttpPort + "/upload:";
        NameValueCollection headers = new NameValueCollection();
        headers.Set("Content-Type", "application/octet-stream");
        headers.Set("Y-Folder", folder);
        headers.Set("Y-File", file);
        using (WebClient wc = new WebClient())
        {
            wc.Credentials = new NetworkCredential(WebUserName, WebPassword);
            wc.Headers.Add(headers);
            wc.UploadData(new Uri(uri), buffer);
            return true;
        }
    }
        catch (Exception ex)
        {
            GlobalData.ODS("Exception in UploadFile " + ex.Message);
            return false;
        }
    }

На сервере

ODS(TraceDetailLevel.Level4, "Process upload ");
HttpListenerResponse response = e.RequestContext.Response;
String disp = "";
String fil = "";
String folder = "";
Stream body = e.RequestContext.Request.InputStream;
long len64 = e.RequestContext.Request.ContentLength64;
Encoding encoding = e.RequestContext.Request.ContentEncoding;
ODS(TraceDetailLevel.Level4, "Process upload " + len64 + " bytes encoding " + encoding.EncodingName);
NameValueCollection nvp = e.RequestContext.Request.Headers;
try
{
disp = nvp["Content-Disposition"];
fil = nvp["Y-File"];
folder = nvp["Y-Folder"];
}
catch { }
BinaryReader reader = new BinaryReader(body, encoding);
byte[] data = new byte[len64];
long total = 0;
while (true)
{
  int dataleft = data.Length - (int)total;
  int offset = (int)total;
  GlobalData.ODS("Reading binary stream offset=" + offset + " read dataleft=" + dataleft);
  int cnt = reader.Read(data, offset, dataleft);
  if (cnt <= 0)
  {
    break;
  }
  total += cnt;
  if (len64 <= total)
  {
    break;
  }
}
ODS(TraceDetailLevel.Level4, "Process upload: Got  data "+total+" should have="+len64);
if (total == len64)
{
  //process data

Приведенный выше код хорошо работает на всех, кроме одной установки. Что случилось?

1 Ответ

5 голосов
/ 20 мая 2011

Похоже, я нашел источник проблемы. На этой единственной установке, которая не работает в моем коде, установлен AVG Free Antivirus на компьютере, на котором работает мой HTTP код сервера. Если я отключу AVG на этом компьютере, мой код будет работать. Хотите знать, если кто-нибудь сталкивается с аналогичными проблемами с AVG.

...