Форум программистов, компьютерный форум, киберфорум
Python: Web
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.98/40: Рейтинг темы: голосов - 40, средняя оценка - 4.98
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300

Request.Response ошибка 400 bad request

16.01.2019, 10:50. Показов 7330. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!

Прошу помочь с обработкой запросов в Python 2.7.11
Принимать реквест и сохранить на сервере файл из него уже получилось, а отправить клиенту респонс пока никак.
В респонсе должен находиться файл PDF. Фидлер показывает что респонс проходит со статусом 200 ОК, но 1С (клиент) не может его обработать - коллеги говорят выбрасывает ошибку 400, видимо респонс имеет неподходящий формат. Может кто выполнял аналогичные задачи?

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def pdf_http_response(file_body):
    # значение file_body вида "%PDF-1.5\r\n%\xb5\xb5\xb5\xb5\r\n1 0 obj\r\n<</Type/..."
    resp = flask.Response(file_body, status=200, mimetype='application/pdf')
    return resp
 
@app.route('/viewer', methods=['POST'])
def viewer_method():
    file_page = int(flask.request.args.get(u'numpage'))
    file_type = flask.request.args.get(u'type')
    file_data = flask.request.files[u'fieldNameHere']
    file_body = file_data.read()
 
    save_temp_file(file_page, file_type, file_body)
 
    resp = pdf_http_response(file_body)
    return resp
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.01.2019, 10:50
Ответы с готовыми решениями:

Ajax post request error
Проблема такая: пытаюсь настроить отправку комментариев к посту посредством аякса views.py: from django.shortcuts import render ...

Научите прикручивать request body
Всем привет, я, так сказать,только на пути к просветлению. Нужно послать с помощью request.post запрос на определеный сайт. С помощью...

Request на Python через Selenium
Подскажите, пожалуйста, как я могу написать код, через Selenium, а не с requests &gt;&gt;&gt; import requests &gt;&gt;&gt; url =...

11
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5969 / 3732 / 1098
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
16.01.2019, 11:45
Цитата Сообщение от SPNick Посмотреть сообщение
коллеги говорят выбрасывает ошибку 400
Может почитать логи сервера?
0
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
16.01.2019, 14:34  [ТС]
Лучший ответ Сообщение было отмечено Рыжий Лис как решение

Решение

Рыжий Лис, попросил посмотреть, ничего не нашли. На сервере Python в логах IIS тоже ничего интересного.

Если у меня в Фидлере в ответе нет "boundary" - это нормально? В запросе он просто есть. Структуры запроса и ответа различаются, не ясно как должно быть (впервые с вебсервисом сталкиваюсь, еще и на python). В дебаге видно, что содержание файла пишется в поле "data".



Начали думать на все подряд - от различий кодировки 1С и Fiddler, до блокировки вложения реквеста прокси-сервером
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5969 / 3732 / 1098
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
16.01.2019, 14:52
Цитата Сообщение от SPNick Посмотреть сообщение
Если у меня в Фидлере в ответе нет "boundary" - это нормально?
Нормально, конечно.

Веб-сервис работает по HTTP (не HTPPS)? Если да, то советую поставить wireshank, впрочем и других инструментов для отладки сетевых протоколов полно.

Есть рабочий пример веб-сервиса? Остаётся только одно: брать ваш веб-сервис и рабочий и сравнивать всё, начиная с заголовков ответа.
0
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
16.01.2019, 15:47  [ТС]
Рыжий Лис, рабочего нет, увы. Работает по HTTP.

Сейчас понял в чем дело.
Я писал код по реквесту, который приходил из Фидлера (не знаю как так получилось). А из 1С приходит сообщение, которое отличается от Фидлеровского. Тут ничего нет в flask.request.files, data тоже пусто. Вот и рушилось все при попытке вычислить
Python
1
file_data = flask.request.files[u'fieldNameHere']
Сижу раскрываю все ветви объекта flask.request, пытаюсь найти где лежит boundary (binary) объект. Пока ничего не нахожу, спрятали (где-то он должен быть, на скрине видно начало данных) о_О

0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5969 / 3732 / 1098
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
16.01.2019, 15:52
А говорил, что в логах всё хорошо

Да сниффером уже тыкни во входящий http-запрос к серверу — быстрее найдёшь данные. Они, кстати, скорей всего тупо лежат в теле POST-запроса бинарником.

Добавлено через 1 минуту
Python
1
request.data
0
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
16.01.2019, 15:53  [ТС]
Рыжий Лис, приложил картинку выше. Сниффером - это вирешарком?
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5969 / 3732 / 1098
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
16.01.2019, 15:57
Python
1
data = request.stream.read()
Добавлено через 1 минуту
Цитата Сообщение от SPNick Посмотреть сообщение
Сниффером - это вирешарком?
Да любым.

Впрочем, моя догадка верна: бинарник тупо лежит в теле post-запроса. Попробуй два моих варианта выше.

Добавлено через 2 минуты
И третий вариант
Python
1
request.get_data()
Какой-нибудь да должен выдать сырые данные из запроса.
1
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
16.01.2019, 16:02  [ТС]
Рыжий Лис, эээх
Python
1
2
3
data1 = flask.request.data дает # дает ''
data2 = flask.request.stream.read() # дает ''
data3 = flask.request.get_data() # дает ''
0
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
17.01.2019, 14:54  [ТС]
Так и не вытащить.
Скрин из WireShark:

в каком-то виде бинарник там все же есть
0
33 / 26 / 19
Регистрация: 21.07.2015
Сообщений: 300
17.01.2019, 15:27  [ТС]
Неизвестно почему, но начало работать. Думаю подкрутили на стороне 1С но никто не признается.
В request.files появилось вложение, успешно получаю и сохраняю его на сервере.

Рыжий Лис, спасибо за помощь.

Python
1
2
3
4
5
6
7
8
9
10
11
12
@app.route('/viewer', methods=['GET', 'POST'])
def viewer_method():
    file_page = int(flask.request.args.get(u'numpage'))
    file_type = flask.request.args.get(u'type')
    file_data = flask.request.files[u'datafile']
    file_body = file_data.read()
    file_decoded_body = base64.decodestring(file_body)
 
    save_temp_file(file_page, file_type, file_decoded_body)
 
    resp = pdf_http_response(file_decoded_body)
    return resp
0
212 / 185 / 32
Регистрация: 24.10.2011
Сообщений: 760
18.01.2019, 11:42
Тупо сервер перезапустили, обнова накатилась и сервисы заработали как надо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.01.2019, 11:42
Помогаю со студенческими работами здесь

Request скрывает в результате теги ngIf
Доброго времени! Есть HTML содержимое &lt;dateformat time=&quot;1619484739&quot; mode=&quot;abs&quot; class=&quot;ng-scope&quot;&gt; &lt;!-- ngIf:...

CSRF verification failed. Request aborted
Есть два представления: def RegEnd(request): #Здесь совершаем действия по чтению ПОСТ данных e_mail = request.POST ...

Модуль request не соединяется через HTTPS прокси
Стоит задача, разработать парсер некого сайта. При частых обращениях к сайту возможен бан. Для исключения бана, обращение к сайту...

Отправка Request payload через Python requests
Помогите плиз отправить запрос такого типа(нижний прямоугольник) запрос выполняется к php скрипту Так же, как я понимаю boundary из...

Как отправить batch-request через Python
Добрый вечер! В браузере отследил batch-запрос (прикрепил в приложения; за качество извиняюсь). Хотел бы сделать такой в python, но через...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Rust и квантовые вычисления: интеграция с Q# и Qiskit
golander 01.06.2025
Мир квантовых вычислений традиционно оставался закрытым клубом для высокоуровневых языков типа Python и специализированных DSL вроде Q#. Однако в последние годы Rust начал тихую революцию в этой. . .
Кэш REDIS и C#
UnmanagedCoder 01.06.2025
Redis (Remote Dictionary Server) - это ультраскоростное хранилище данных в оперативной памяти, работающее по принципу "ключ-значение". Суть проста: данные хранятся не на диске, а прямо в RAM, что. . .
Lenovo IH110CX Rev 1.0 user manual
Maks 01.06.2025
Размещения без повторений
VistaSV30 31.05.2025
Код возвращает список вариантов размещений A^{k}_{n}=\frac{n!}{(n-k)!} from itertools import permutations def pwr(k, n): # Размещение без повторений (Placement without repetition) if k. . .
Redis и Node.js с TypeScript - решения для высоконагруженных систем
Reangularity 31.05.2025
Redis (Remote Dictionary Server) — сверхбыстрое хранилище данных в памяти, способное обрабатывать операции за микросекунды. И что особенно важно для нас — с удивительно простым API. А теперь. . .
Unit-тестирование с моками в Go
golander 31.05.2025
Большинство разработчиков предпочитают тестировать код без использования моков. Например, при интеграции с Elasticsearch логичнее запустить контейнер локально и тестировать Go-код непосредственно с. . .
Как работать с PDF в C#
stackOverflow 31.05.2025
Нам приходится сталкиваться с PDF по разным причинам. Генерация счетов, создание отчетов, извлечение данных из загруженных пользователем документов, автоматизация рабочих процесов - это лишь верхушка. . .
Двухбуквенные коды стран в шифровании.
russiannick 31.05.2025
Человечество издревле манила возможность замены сочетаний букв вымышленными символами, делающие сообщение понятным только для посвещенных. Настала пора внести в это свой вклад. Двухбуквенные коды. . .
Мой опыт в исправлении ошибки приложения Boinc в части заряда батареи смартфона.
Programma_Boinc 31.05.2025
Мой опыт в исправлении ошибки приложения Boinc в части заряда батареи смартфона. Хотел бы поделиться опытом в исправлении ошибки приложения в части заряда батареи смартфона. Сразу скажу, что. . .
Добро пожаловать на конкурс PrimeGrid, посвященный 20-летию PrimeGrid
Programma_Boinc 31.05.2025
Добро пожаловать на конкурс PrimeGrid, посвященный 20-летию PrimeGrid: 5-дневный обобщенный поиск простых чисел Ферма n = 20 с 12 июня 20:20 UTC по 17 июня 20:20 UTC. 12 июня 2005 года. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
OSZAR »