Мне нужно использовать HttpWebClient для одновременной загрузки ряда файлов.
Я следую примеру кода, найденного в этой теме:
Загрузка файлов с помощью HTTPWebrequest (multipart /данные формы)
Поскольку несколько человек сообщили в этом потоке, я также получаю ошибки HTTP status 500.Я попробовал 2 решения, предложенные в теме, но ни одно из них не работает для меня.Кажется, что в запросе есть какая-то проблема, связанная с пробелами, но я не смог ее выяснить.
Вопросы:
Какой ресурс мне нужноиспользуется для проверки правильности форматирования HTTP-запроса?
Должна быть возможность вручную написать запрос, если я скопирую и вставлю раздел файла, верно?
Если вам известен пример работающего кода, пожалуйста, дайте мне знать.
Вот код, который я использую:
public static void UploadFilesToRemoteUrl(string url, string[] files,
string logpath, NameValueCollection nvc)
{
long length = 0;
string boundary = "----------------------------" +
DateTime.Now.Ticks.ToString("x");
HttpWebRequest httpWebRequest2 = (HttpWebRequest)WebRequest.Create(url);
httpWebRequest2.ContentType = "multipart/form-data; boundary=" +
boundary;
httpWebRequest2.Method = "POST";
httpWebRequest2.KeepAlive = true;
httpWebRequest2.Credentials =
System.Net.CredentialCache.DefaultCredentials;
Stream memStream = new System.IO.MemoryStream();
byte[] boundarybytes = System.Text.Encoding.ASCII.GetBytes("\r\n--" +
boundary + "\r\n");
string formdataTemplate = "\r\n--" + boundary +
"\r\nContent-Disposition: form-data; name=\"{0}\";\r\n\r\n{1}";
foreach (string key in nvc.Keys)
{
string formitem = string.Format(formdataTemplate, key, nvc[key]);
byte[] formitembytes = System.Text.Encoding.UTF8.GetBytes(formitem);
memStream.Write(formitembytes, 0, formitembytes.Length);
}
memStream.Write(boundarybytes, 0, boundarybytes.Length);
string headerTemplate = "Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"\r\n Content-Type: application/octet-stream\r\n\r\n";
for (int i = 0; i < files.Length; i++)
{
//string header = string.Format(headerTemplate, "file" + i, files[i]);
string header = string.Format(headerTemplate, "uplTheFile", files[i]);
byte[] headerbytes = System.Text.Encoding.UTF8.GetBytes(header);
memStream.Write(headerbytes, 0, headerbytes.Length);
FileStream fileStream = new FileStream(files[i], FileMode.Open,
FileAccess.Read);
byte[] buffer = new byte[1024];
int bytesRead = 0;
while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)
{
memStream.Write(buffer, 0, bytesRead);
}
memStream.Write(boundarybytes, 0, boundarybytes.Length);
fileStream.Close();
}
httpWebRequest2.ContentLength = memStream.Length;
Stream requestStream = httpWebRequest2.GetRequestStream();
memStream.Position = 0;
byte[] tempBuffer = new byte[memStream.Length];
memStream.Read(tempBuffer, 0, tempBuffer.Length);
memStream.Close();
requestStream.Write(tempBuffer, 0, tempBuffer.Length);
requestStream.Close();
WebResponse webResponse2 = httpWebRequest2.GetResponse();
Stream stream2 = webResponse2.GetResponseStream();
StreamReader reader2 = new StreamReader(stream2);
MessageBox.Show(reader2.ReadToEnd());
webResponse2.Close();
httpWebRequest2 = null;
webResponse2 = null;
}
Обновление:
Спасибо, что поблагодарили меня за продолжение использования скрипача.Это было направление, в котором мне нужно было найти решение этой проблемы.
Теперь позвольте мне ответить на вопросы здесь.
1.Какой ресурс следует использовать для проверки правильности форматирования HTTP-запроса? a) Стандарты. Существует RFC1867 http://www.faqs.org/rfcs/rfc1867.html.Приятно читать.Он объясняет, кому должна выполняться множественная загрузка, а также как вы обрабатываете другие данные формы.Ограничение состоит в том, что в нем прямо не сказано, как запрос должен быть отформатирован с точки зрения количества CRLF между каждым заголовком и значениями.Я подозреваю, что информация может быть в HTTP RFC 2616 http://www.w3.org/Protocols/rfc2616/rfc2616.html, но это немного более длительное чтение, чем у меня было время.Кроме того, может быть некоторая возможность для интерпретации между различными его реализациями.
b) Фактические примеры. Выигрышная комбинация для получения реальных примеров использовала вместе curl и fiddler.Я смог отправить правильный запрос на загрузку через curl, но - curce --trace-ascii не давал мне необработанный заголовок, который мне был нужен.Аппроксимации, которые я сделал на основе этого, продолжали терпеть неудачу, и fiddler, похоже, не захватывал его трафик.
Затем я нашел ссылку, объясняющую, что curl не использует прокси системы.Таким образом, чтобы захватить его трафик на fiddler, нужно ввести curl -x 127.0.0.1:8888 www.happysmurfs.com Теперь я получил необработанный заголовок, который мне был нужен.ТЕПЕРЬ, с правильным необработанным заголовком, устранение неполадок в коде было простым, так как у меня был другой текстовый заголовок для сравнения с ним.
2.Должна быть возможность написать запрос вручную, если я скопирую и вставлю раздел файла, верно? Да, кажется, что это возможно, но, как упоминалось в ck, намного проще получить рабочий, проверенный заголовок изскрипач, а затем внести изменения оттуда.
3.Если вам известен пример кода, который работает, пожалуйста, дайте мне знать. Код выше должен работать, но обратите внимание на эту строку:
string formdataTemplate = "\r\n--" + boundary +
"\r\nContent-Disposition: form-data; name=\"{0}\";\r\n\r\n{1}";
Первый \ r \ n не должен бытьтам.Кроме того, не должно быть двойных новых строк (\ r \ n) в конце заголовков или границ.