Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
36 / 25 / 12
Регистрация: 08.04.2013
Сообщений: 269

HttpWebRequest Post запрос с разделителем и файлом

26.09.2016, 16:22. Показов 3034. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Пересмотрел кучу примеров в интернете, но так и не могу понять как написать код. Обычные POST делаю без проблем.
В общем запрос заголовки запроса выглядят так:
Кликните здесь для просмотра всего текста
URL: http://localhost/files/add
HOST: "localhost"
User-Agent: "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0"
Accept: "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"
Accept-Language: "ru-RU,ru;q=0.8,en-US;q=0.5,en;q=0.3"
Accept-Encoding: "gzip, deflate"
Referer: "http://localhost/docs"
Cookie: "blablabla"
DNT: "1"
Connection: "keep-alive"
Upgrade-Insecure-Requests: "1"

Все понятно, кроме параметров DNT и Upgrade-Insecure-Requests: "1". Как понимаю надо просто добавить хедер с такой записью?

А дальше параметры:
Кликните здесь для просмотра всего текста

Content-Type: multipart/form-data; boundary=---------------------------181162868218259
Content-Length: 525

-----------------------------181162868218259
Content-Disposition: form-data; name="FILE"; filename="test.txt"
Content-Type: text/plain

text in file//передаваемые данные
-----------------------------181162868218259
Content-Disposition: form-data; name="PFTYPPE_ID"

3//константа
-----------------------------181162868218259
Content-Disposition: form-data; name="DESCRIPTION"

descriptionText//описание добавляемого файла
-----------------------------181162868218259
Content-Disposition: form-data; name="DOC_ID"

12345//номер документа
-----------------------------181162868218259--


С boundary понятно. В начале параметров прописано что длина контента равна 525 байт, хотя по факту в параметрах 607 байт. Каким образом вычислить Content-Type: text/plain? Т.е. если я закидываю картинку, то тип контента автоматически меняется. Данные буду брать типа LONGBLOB из MySQL.

Помогите, пожалуйста. Чувствую что делается элементарно, но уже запутался окончательно. В описываемых в Интернете примерах данные между разделителями отправляются отдельно, а тут получается что надо сначала сформировать параметры, а потом отправить.

Добавлено через 22 часа 14 минут
как оказалось с boundary не понятно. Конкретно непонятно как он формируется.
пробовал два варианта:
C#
1
2
var boundary = new string('-', 27) + DateTime.Now.Ticks.ToString("x", NumberFormatInfo.InvariantInfo);
var boundary2 = new string('-', 27) + DateTime.Now.Ticks.ToString();
оба выдают значения, сильно отличающиеся от boundary, которые генерирует веб-приложение.
Вот параметры, передаваемые пост-запросом, который формируется при заполнении формы в браузере:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
ontent-Type: multipart/form-data; boundary=---------------------------31292891730670
Content-Length: 508
 
-----------------------------31292891730670
Content-Disposition: form-data; name="FILE"; filename="test.txt"
Content-Type: text/plain
 
text in file
-----------------------------31292891730670
Content-Disposition: form-data; name="PFTYPPE_ID"
 
3
-----------------------------31292891730670
Content-Disposition: form-data; name="DESCRIPTION"
 
111
-----------------------------31292891730670
Content-Disposition: form-data; name="DOC_ID"
 
1049916
-----------------------------31292891730670--
Я формирую параметры так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
byte[] file = (byte[])reader[2];
StringBuilder sb = new StringBuilder();
sb.AppendLine(boundary2);
sb.AppendLine("Content-Disposition: form-data; name="FILE"; filename="" + reader[1].ToString() + """);
sb.AppendLine("Content-Type: " + getMimeFromFile(file));
sb.AppendLine("");
byte[] nachalo = Encoding.ASCII.GetBytes(sb.ToString());
boundary = "--" + boundary2;
StringBuilder sb2 = new StringBuilder();
sb2.AppendLine(boundary);
sb2.AppendLine("Content-Disposition: form-data; name="PFTYPPE_ID"");
sb2.AppendLine("3");
sb2.AppendLine(boundary);
sb2.AppendLine("Content-Disposition: form-data; name="DESCRIPTION"");
sb2.AppendLine("1 ");
sb2.AppendLine(boundary);
sb2.AppendLine("Content-Disposition: form-data; name="DOC_ID"");
sb2.AppendLine(Number);
sb2.AppendLine(boundary + "--");                            
byte[] konec = Encoding.ASCII.GetBytes(sb2.ToString());
byte[] res = nachalo.Concat(file).Concat(konec).ToArray();
В ответ сервер мне выдает что не заданы параметры для файла.

Добавлено через 1 час 32 минуты
Сделал для теста изменение и отправку файла через браузер, изменил boundary и в ответ получаю все тот же ответ что не заданы все параметры для файла. Когда файл передается, то при корректном ответе возвращается JSON такого вида:
JSON
1
{"success":true,"result":{"DOC_ID":1049902,"FKEY":"1e563586f1a4f010e9bd583e1e4becc1aea98e7857e91a49b947e6.01081115","ID":null}}
Что это может быть за ключ? Может надо чтобы boundary формировался на стороне сервера?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.09.2016, 16:22
Ответы с готовыми решениями:

HttpWebRequest асинхронный post запрос
Мне нужно создать post запрос и послать его асинхронно делаю это вот так: HttpWebRequest request =...

[HttpWebRequest] Сервер не читает POST запрос
Есть код: Клиент HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://test.local/C.php"); request.ContentType =...

Post запрос HttpWebRequest через прокси socks5
Есть код простого пост запроса string POST(string url, string data) { HttpWebRequest request =...

5
36 / 25 / 12
Регистрация: 08.04.2013
Сообщений: 269
27.09.2016, 17:49  [ТС]
Итак. Выяснилось, что серверная часть построена на EXT JS(SENCHA).
Перед выполнением POST идет запрос к функции doFormUpload в файле ext-all.js
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
doFormUpload: function (q, j, k) {
      var l = Ext.id(),
      v = document,
      r = v.createElement('iframe'),
      m = Ext.getDom(q.form),
      u = [
      ],
      t,
      p = 'multipart/form-data',
      n = {
        target: m.target,
        method: m.method,
        encoding: m.encoding,
        enctype: m.enctype,
        action: m.action
      };
Чем можно проснифить параметры, которые отправляются данной функции?

Добавлено через 53 минуты
Пропарсил...

q - объект формы
j - DOC_ID
k - url для пост-запроса

Вопрос: объект внешне через отладчик FireFox похож на JSON объект. Действительно ли это так? Может кто-то работал с подобным из Windows Forms
0
36 / 25 / 12
Регистрация: 08.04.2013
Сообщений: 269
02.10.2016, 08:52  [ТС]
Нашел решение проблемы в Интернете.

Метод загрузки файла параметрами и разделителями:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
        public void HttpUploadFile(string url, string file, string paramName, string contentType, NameValueCollection nvc)
        {
            string boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x");
            byte[] boundarybytes = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "\r\n");
 
            HttpWebRequest wr = (HttpWebRequest)WebRequest.Create(url);
            wr.ContentType = "multipart/form-data; boundary=" + boundary;
            wr.Method = "POST";
            wr.KeepAlive = true;
            wr.Credentials = System.Net.CredentialCache.DefaultCredentials;
            wr.CookieContainer = cookies;
            Stream rs = wr.GetRequestStream();
            string formdataTemplate = "Content-Disposition: form-data; name="{0}"\r\n\r\n{1}";
            foreach (string key in nvc.Keys)
            {
                rs.Write(boundarybytes, 0, boundarybytes.Length);
                string formitem = string.Format(formdataTemplate, key, nvc[key]);
                byte[] formitembytes = System.Text.Encoding.UTF8.GetBytes(formitem);
                rs.Write(formitembytes, 0, formitembytes.Length);
            }
            rs.Write(boundarybytes, 0, boundarybytes.Length);
            string headerTemplate = "Content-Disposition: form-data; name="{0}"; filename="{1}"\r\nContent-Type: {2}\r\n\r\n";
            string header = string.Format(headerTemplate, paramName, file, contentType);
            byte[] headerbytes = System.Text.Encoding.UTF8.GetBytes(header);
            rs.Write(headerbytes, 0, headerbytes.Length);
            FileStream fileStream = new FileStream(file, FileMode.Open, FileAccess.Read);
            byte[] buffer = new byte[4096];
            int bytesRead = 0;
            while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)
            {
                rs.Write(buffer, 0, bytesRead);
            }
            fileStream.Close();
            byte[] trailer = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "--\r\n");
            rs.Write(trailer, 0, trailer.Length);
            rs.Close();
            WebResponse wresp = null;
            try
            {
                wresp = wr.GetResponse();
                Stream stream2 = wresp.GetResponseStream();
                StreamReader reader2 = new StreamReader(stream2);
                var result = reader2.ReadToEnd();
                string rss = result.ToString();
            }
            catch (Exception ex)
            {
                MessageBox.Show("Error occurred while converting file", "Error!");
                if (wresp != null)
                {
                    wresp.Close();
                    wresp = null;
                }
            }
            finally
            {
                wr = null;
            }
        }
Вызов:
C#
1
2
3
4
5
6
7
NameValueCollection parameters = new NameValueCollection();
parameters.Add("PFTYPPE_ID", "3");
parameters.Add("DESCRIPTION", " ");
parameters.Add("DOC_ID", Number);
string fullPath = Path.GetFullPath(reader[3].ToString());
string MIME = GetMimeType(reader[2].ToString());
HttpUploadFile("http://url", fullPath, "FILE", MIME , parameters);
0
979 / 874 / 350
Регистрация: 26.04.2012
Сообщений: 2,647
02.10.2016, 16:25
Какие-то жуткие мучения на ровном месте... HttpClient используйте для подобных запросов...

Добавлено через 1 минуту
А чтобы понять, какие параметры реально необходимы, а без каких можно и обойтись, используйте функционал вкладки Composer в Fiddler.
0
36 / 25 / 12
Регистрация: 08.04.2013
Сообщений: 269
02.10.2016, 23:11  [ТС]
EvilFromHell, можете показать аналог приведенного мной кода с помощью HttpClient?
0
979 / 874 / 350
Регистрация: 26.04.2012
Сообщений: 2,647
03.10.2016, 00:59
lemeserg, я нигде не вижу URLа, на который все это шлется, а потому проверить правильность написанного кода все равно не смогу. Лучше вы посмотрите примеры. Вот. Только вам надо использовать MultipartFormDataContent, а так разницы между вашим запросом и приведенным в примере POST запросом не много.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.10.2016, 00:59
Помогаю со студенческими работами здесь

Не получается POST-запрос с передачей файлов через HttpWebRequest
пытаюсь сделать POST-запрос типа MIME на сайт... должен передавать несколько файлов и значение одной переменной... не получается даже с...

POST запрос с прикрепленным файлом
Здраствуйте, уважаемые пользователи портала. Суть проблемы: Не могу отправить POST запрос стандартными средствами (idHTTP) с прикрепленным...

Работа с текстовым файлом-прочитать посимвольно с определенным разделителем строк
Добрый день всем!Вот хочу написать код чтобы он читал байты посимвольно до разделителя строк-";".И этот массив char преобразовал...

HttpWebRequest Post
Здравствуйте. Помогите разобраться новичку. Вообщем написал я небольшую програмку, которая может авторизироваться на сайте и отправлять...

HttpWebRequest - отправка файла POST запросом
Добрый день! Пытаюсь отправить содержимое файла (не сам файл, а именно содержимое), но до сервера оно не доходит.. public void...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru