1с post запрос ошибка 400

  

Paradox

28.10.17 — 12:37

Добрый день!

Платформа: 8.3.10.2299.

До перехода на HTTPs, обращался к веб-сервису без проблем по HTTP соединению (авторизация доменная):

HTTP = Новый HTTPСоединение(ИмяСервера, Порт, , , , , , Истина);

Когда сделали HTTPs, то доделал строку соединения до вида:

HTTP = Новый HTTPСоединение(ИмяСервера, 443, , , , , Новый ЗащищенноеСоединениеOpenSSL(), Истина);

Методы веб-сервиса и структура базы веб-сервиса не менялась. Просто администраторы сделали HTTPs.

Теперь при выполнении PUT-запроса получаю ошибку 400. Подскажите, пожалуйста, в чем может быть дело? Проблема на стороне веб-сервиса или я что-то не правильно указал в HTTPСоединении?

Текст ошибки:

Единицы измерения; {ВнешняяОбработка.ВыгрузкаВВебСервис.Форма.Форма.Форма(307)}: Ошибка выгрузки. Код ошибки: 400

<!DOCTYPE HTML PUBLIC «-//W3C//DTD HTML 4.01//EN»»http://www.w3.org/TR/html4/stri… »»»>

<HTML><HEAD><TITLE>Bad Request</TITLE>

<META HTTP-EQUIV=»Content-Type» Content=»text/html; charset=us-ascii»></HEAD>

<BODY><h2>Bad Request — Invalid Verb</h2>

<hr><p>HTTP Error 400. The request verb is invalid.</p>

</BODY></HTML>

  

Филиал-msk

1 — 28.10.17 — 13:33

(0) > The request verb is invalid

Не надо в него PUT, не хочет он этого.

  

Paradox

2 — 28.10.17 — 14:33

(1) а ведь до этого (до перехода на HTTPs) именно PUT-запрос происходил из 1С в сервис и все отлично было.

К администратору надо обратиться?)

  

Филиал-msk

3 — 28.10.17 — 14:40

(2) Не знаю, что у вас там под веб-сервисом понимается, но SOAP, он какбе вообще-то POST подразумевает.

Пытай админов, почему типы запросов стали по разному обрабатываться. А то сейчас окажется что, например, перед аппликейшн сервером возник какой нить энджинх для поддержки SSL со своими представлениями о мире.

  

Paradox

4 — 28.10.17 — 14:46

(3) не совсем понимаю в веб-технологиях, но разработчики веб-сервиса сделали сервис не в 1С. Сказали выгружать данные в сервис PUT-запросами, а тело запроса в формате JSON.

До HTTPs, все отлично работало. Вчера перевели на защищенное соединение и пипец…походу надо копать именно сам сервис, что-то в нем случилось.

  

Paradox

5 — 28.10.17 — 14:50

(1) The request verb is invalid

Могу я судить по этому сообщению, что 1С устанавливает соединение защищенное и тут уже сам сервер, на котором поднят веб-сервис отвергает мой PUT-запрос?

  

Филиал-msk

6 — 28.10.17 — 15:56

(5) Да, SSL работает. Ты успешно попадаешь на веб сервер со свои непристойным предложением пута.

  

Филиал-msk

7 — 28.10.17 — 15:59

(4) Скорей всего одновременно с накатыванием SSL чтойто порубили во избежание или по недосмотру. Одмины могут.

  

sitex

8 — 28.10.17 — 17:02

(5)А вы точно тело в json отправляете ? попробуйте на этот сервис отправить PUT запрос  через Postman.

  

Филиал-msk

9 — 28.10.17 — 17:27

(8) Postman отстой, пользуйте Fiddler

  

sitex

10 — 28.10.17 — 17:29

(9) Аргументируй . Если не умеешь им пользоваться это не означает что продукт плох.

  

Paradox

11 — 28.10.17 — 17:46

по ссылке, которую предоставили разработчики веб-сервиса, открывается Swagger UI, где я могу сделать GET, PUT запросы.

Вот через этот интерфейс PUT нормально выполняется.

  

Филиал-msk

12 — 28.10.17 — 17:49

(10) Требует дрочки вприсядку при организации тестирования. Продукт плох.

  

sitex

13 — 28.10.17 — 17:49

(12) ну как я и думал аргумент весомый.

  

sitex

14 — 28.10.17 — 17:52

(11) Пробовали «WinHttp.WinHttpRequest.5.1» ?

  

Филиал-msk

15 — 28.10.17 — 17:52

(11) Интерфейс на https? Ты точно в нужный сервер попадаешь своим начальным CONNECT на https?

  

Paradox

16 — 28.10.17 — 17:54

(11) не пробовал

  

Филиал-msk

17 — 28.10.17 — 17:55

(13) А ты ценитель, однако.

  

Paradox

18 — 28.10.17 — 17:55

(12) это как понять? Я делаю в 1С, на HTTP работало без проблем. После перехода на HTTPs в коде добавил только объявление

Новый ЗащищенноеСоединениеOpenSSL()

  

sitex

19 — 28.10.17 — 17:57

(17) Фи Фи фи забыл добавить.

  

Филиал-msk

20 — 28.10.17 — 17:57

(16) Попробуй. Там дело в том, что при установке ssl сначала вылетает CONNECT, а твой PUT пойдет уже внутри канала. Если сервер CONNECT не ожидает, ты получишь такую же ошибку.

Вдруг он ждет SSL на 8443 каком нибудь.

  

Paradox

21 — 28.10.17 — 18:00

Вот сама процедура отправки запроса. Буду пробовать win http.

    ИмяСервера     = "*****";
    Порт         = 443;
    ИмяМетода     = "***" + ИмяМетода;
    
    HTTP = Новый HTTPСоединение(ИмяСервера, Порт, , , , , Новый ЗащищенноеСоединениеOpenSSL(), Истина); 
    
    ЗаголовокЗапросаHTTP = Новый Соответствие();
    ЗаголовокЗапросаHTTP.Вставить("Content-Type", "application/json-patch+json");
    ЗапросPUT = Новый HTTPЗапрос(ИмяМетода + "/" + РезультатЗапроса.Объекты.Guid1c, ЗаголовокЗапросаHTTP);
     
    
    ЗапросPUT.УстановитьИмяФайлаТела(ПутьКФайлу);
    Возврат HTTP.Записать(ЗапросPUT);

  

sitex

22 — 28.10.17 — 18:03

(20) Я думаю разрабы сообщили бы что у них запросы завернуты на другой порт.

  

sitex

23 — 28.10.17 — 18:11

(21) Как вариант вызвать на прямую HTTP.ВызватьHTTPМетод(«PUT»,ЗапросPUT);

  

Paradox

24 — 28.10.17 — 18:27

(23) Капец…заработало…в чем разница между Записать() и ВызватьHTTPМетод()

во втором случае работает, а в первом нет.

  

Paradox

25 — 28.10.17 — 18:28

(23) и при этом в «PUT » — надо обязательно пробел…

  

sitex

26 — 28.10.17 — 18:29

(24) Значит что то в 1 случае в заголовках сто то не то. сравните.

  

Paradox

27 — 28.10.17 — 18:31

(26) так заголовки такие же остаются…или что-то другое имеется ввиду?

 ЗаголовокЗапросаHTTP = Новый Соответствие();
    ЗаголовокЗапросаHTTP.Вставить("Content-Type", "application/json-patch+json");

  

sitex

28 — 28.10.17 — 18:34

(27) Вообще хорошо бы на стороне сервера узнать что в логах падает в первом случае. Спросите у разрабов. Может в 1 случае там вообще не PUT а что то другое.

  

sitex

29 — 28.10.17 — 18:38

(25) НА счет этого я задавал вопрос в поддержку , внятного ответа так и не получил в чем разница. Если кто знает в чем разница с пробелом или нет.

Здравствуйте.
Это мой первый вопрос здесь. Возможно, найдется, кто понимает, в чём тут дело. Спасибо.
———————————————————————————————
Есть веб-сервис и общая команда. В общей команде код:

Попытка
        ВСОпределение = Новый WSОпределения("http://192.168.___.__/t10/ws/OD.1cws?wsdl";); //#1
        ВСервер = ВСОпределение.Сервисы.Получить("OD","OD");
        ВТочкаВхода = ВСервер.ТочкиПодключения.Получить("ODSoap");
        ВТОперация = ВТочкаВхода.Интерфейс.Операции.Получить("Sinhron");
        Данные = Новый ХранилищеЗначения("Некие данные",Новый СжатиеДанных(9));
        ДанныеXDTO = ВСОпределение.ФабрикаXDTO.Создать(ВТОперация.Параметры.Получить("Dan").Тип,Данные);
        ВСПрокси = Новый WSПрокси(ВСОпределение,"OD","OD","ODSoap");
        Ответ = ВСПрокси.Синхронизация(ДанныеXDTO);    
        Возврат Истина;    
    Исключение
        Сообщить(ОписаниеОшибки());
        Возврат Ложь;    
    КонецПопытки;

При нажатии на кнопку ВыполнитьСинхронизацию сначала было все хорошо, т.е. выполнение шло по ветке Попытка, до Ответ доходило точно, в ветку Исключение выполнение не переходило.

Но затем, не понятно почему, при очередном тестировании кнопки с общей командой, сразу после прохождения строки кода #1 выполнение стало переходить к Исключению и в
результате — ошибка (указывает именно на эту строку кода (выше) и код ошибки 400).

(1с и Apache2.2 переустановил — не помогло)

При этом базу в браузере вижу, xml-файл тоже.
————————————
Примерно в момент возникновения этой ошибки началось следующее: даже если база нигде не открыта (ни в браузере, ни на ПК), выдается сообщение: “Достигнуто предельное количество подключений к ИБ”. Чтобы выходить из этой ситуации приходится часто чистить кэш и останавливать сервер.

Что это может быть? Как исправить?

Ошибка при авторизации в 1С.Маркировка МДПЛ по сертификату: при выполнении POST-запроса по адресу /api/v1/auth, error_code, api.authentication.error, error_description. Проверьте аутентификационные данные

Описание ошибки:
При попытке выполнить авторизацию на api-сервер Маркировки из модуля МДЛП в 1С 8:
Ошибка при выполнении POST-запроса по адресу /api/v1/auth
[400] Запрос не может быть исполнен.
{«error_code»:»api.authentication.error»,»error_description»:»Ошибка при
выполнении операции: Проверьте аутентификационные данные»}

Найденные решения:

В модуле обмена 1С.Маркировка МДЛП после нажатия на кнопку «Выполнить обмен» и выбора сертификата для подписи при попытке авторизации возникает окно «Не удалось подписать данные» с содержанием ошибки, представленным выше.

Нажатие на изображении увеличит его
1С 8 как исправить ошибку Ошибка при выполнении POST-запроса по адресу /api/v1/auth [400] Запрос не может быть исполнен.<br>
Рис.1. Момент возникновения ошибки «Ошибка при выполнении POST-запроса по адресу . /api/v1/auth. Проверьте аутентификационные данные»

Проблема исходя из описания самой ошибки заключается в том, что какие-то данные для подключения не подходят. На этом этапе обычно в промышленном контуре на сайте mdlp.crpt.ru, уже должна быть добавлена «Учётная система» в разделе «Администрирование». Поэтому первым делом необходимо проверить заполнение элемента справочника «Организации МДЛП» для «Собственной организации». Реквизит «Регистрационный номер участника» должен быть использован из профиля организации. А реквизиты «Идентификатор клиента» и «Секретный код» должны совпадать с данными раздела «Администрирование. Учетные системы» кабинета МДЛП для вашей организации. Для API «Промышленной системы» и «Тестовая система МДЛП («Песочница») значение реквизитов отличаются. Это необходимо учитывать и изменить при необходимости.

Нажатие на изображении увеличит его
1С 8 как исправить {"error_code":"api.authentication.error","error_description":"Ошибка при выполнении операции: Проверьте аутентификационные данные"}
Рис. 2. Пример с сайта infostart корректности заполнения полей настройки в 1С по данным учетной системы в кабинете МДЛП

Если будут перепутаны и не туда введены какие-либо из трех идентификаторов (рег. номер участника, идентификатор клиента или секретный код), то будет возникать ошибка. Так же если выбран не верный «Адрес API» в «Настройки и справочники» модуля МДЛП в 1С 8. В данном исходно был установлено значение «api.sb.mdlp.crpt.ru». Это не подходило.

Нажатие на изображении увеличит его
1C 8 Ошибка при выполнении POST-запроса по адресу /api/v1/auth [400] Запрос не может быть исполнен. {"error_code":"api.authentication.error","error_description":"Ошибка при выполнении операции: Проверьте аутентификационные данные"}
Рис. 3. Выбор адреса API в настройках модуля МДЛП в базе 1С 8.

После выбора значения «Промышленная система» подпись данных стала выполняться без возникновения ошибки.

Нажатие на изображении увеличит его

Рис. 4. Значение адреса API после выбора значения «Промышленная система».

Оцените, помогло ли Вам предоставленное описание решения ошибки?




© www.azhur-c.ru 2014-2020. Все права защищены. Использование текстов и изображений с данной страницы без письменного разрешения владельца запрещено. При использовании материалов с данной страницы обязательно указание ссылки на данную страницу.

20-09-2022

Журавлев А.С.
(Сайт azhur-c.ru)

5 / 5 / 5

Регистрация: 17.12.2013

Сообщений: 200

1

07.06.2016, 12:43. Показов 8610. Ответов 3


Добрый день
Есть запрос, который хотим отправлять через http

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

1C
1
ВЫБРАТЬ НАЧАЛОПЕРИОДА(ХозрасчетныйДвиженияССубконто.Период, ДЕНЬ) КАК Дата,ГОД(ХозрасчетныйДвиженияССубконто.Период) КАК Год,МЕСЯЦ(ХозрасчетныйДвиженияССубконто.Период) КАК Месяц,ХозрасчетныйДвиженияССубконто.Регистратор.Номер КАК Номер,ХозрасчетныйДвиженияССубконто.СчетДт КАК Счет,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код =000000010“ ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт1 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт2 КОНЕЦ КАК Подразделение,ВЫБОР ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1 КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код =000000010“ ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт2 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт1 КОНЕЦ КАК СтатьяЗатрат,ХозрасчетныйДвиженияССубконто.СубконтоКт1 КАК Контрагент,ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоКт1) КАК КонтрагентПредставление,ХозрасчетныйДвиженияССубконто.СубконтоДт3 КАК НомГруппа,ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоДт3) КАК НомГруппаПредставление,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL  ТОГДА -ХозрасчетныйДвиженияССубконто.Сумма ИНАЧЕ -ХозрасчетныйДвиженияССубконто.ВалютнаяСуммаКт КОНЕЦ КАК Сумма,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL ТОГДА Константы.ВалютаУправленческогоУчета ИНАЧЕ ХозрасчетныйДвиженияССубконто.ВалютаКт КОНЕЦ КАК Валюта,-ХозрасчетныйДвиженияССубконто.Сумма КАК Сумма1,ХозрасчетныйДвиженияССубконто.Регистратор КАК Регистратор,ХозрасчетныйДвиженияССубконто.Содержание КАК Содержание ИЗ РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто(ДАТАВРЕМЯ(2015, 10, 01), ДАТАВРЕМЯ(2015, 10, 31), СчетДт.Код =91“ ИЛИ СчетДт.Код =92“ ИЛИ СчетДт.Код =93,, ) КАК ХозрасчетныйДвиженияССубконто, Константы КАК Константы

При выполнении получаю ошибку
Invoke-RestMethod : Bad Request — Invalid URL
HTTP Error 400. The request URL is invalid.

В чем может быть ошибка?

Добавлено через 3 минуты
Также пробуем вместо двойных кавычек использовать !!! и вместо запятых %%%,

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

1C
1
ВЫБРАТЬ НАЧАЛОПЕРИОДА(ХозрасчетныйДвиженияССубконто.Период, ДЕНЬ) КАК Дата%%% ГОД(ХозрасчетныйДвиженияССубконто.Период) КАК Год%%% МЕСЯЦ(ХозрасчетныйДвиженияССубконто.Период) КАК Месяц%%% ХозрасчетныйДвиженияССубконто.Регистратор.Номер КАК Номер%%% ХозрасчетныйДвиженияССубконто.СчетДт КАК Счет%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код = !!!000000010!!! ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт1 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт2 КОНЕЦ КАК Подразделение%%% ВЫБОР ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1 КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код = !!!000000010!!! ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт2 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт1 КОНЕЦ КАК СтатьяЗатрат%%% ХозрасчетныйДвиженияССубконто.СубконтоКт1 КАК Контрагент%%% ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоКт1) КАК КонтрагентПредставление%%% ХозрасчетныйДвиженияССубконто.СубконтоДт3 КАК НомГруппа%%% ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоДт3) КАК НомГруппаПредставление%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL  ТОГДА -ХозрасчетныйДвиженияССубконто.Сумма ИНАЧЕ -ХозрасчетныйДвиженияССубконто.ВалютнаяСуммаКт КОНЕЦ КАК Сумма%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL ТОГДА Константы.ВалютаУправленческогоУчета ИНАЧЕ ХозрасчетныйДвиженияССубконто.ВалютаКт КОНЕЦ КАК Валюта%%% -ХозрасчетныйДвиженияССубконто.Сумма КАК Сумма1%%% ХозрасчетныйДвиженияССубконто.Регистратор КАК Регистратор%%% ХозрасчетныйДвиженияССубконто.Содержание КАК Содержание ИЗ РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто(ДАТАВРЕМЯ(2015, 10, 01), ДАТАВРЕМЯ(2015, 10, 31), СчетДт.Код = !!!91!!! ИЛИ СчетДт.Код = !!!92!!! ИЛИ СчетДт.Код = !!!93!!!, , ) КАК ХозрасчетныйДвиженияССубконто, Константы КАК Константы

, но результат такой же

__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь

0

Раздражает, когда какой-то сайт не загружается и отзывается непонятными ошибками. Обычно они сопровождаются одним из десятков HTTP-кодов, которые как раз намекают на характер сбоя, а также его вероятные причины. 

В этом материале поговорим об ошибке 400 Bad Request. Почему она появляется и как ее исправить. 

Как и другие коды, начинающиеся на четверку, 400 Bad Request говорит о том, что возникла проблема на стороне пользователя. Зачастую сервер отправляет ее, когда появившаяся неисправность не подходит больше ни под одну категорию ошибок. 

Стоит запомнить — код 400 напрямую связан с клиентом (браузером, к примеру) и намекает на то, что отправленный запрос со стороны пользователя приводит к сбою еще до того, как его обработает сервер (вернее, так считает сам сервер). 

Комьюнити теперь в Телеграм

Подпишитесь и будьте в курсе последних IT-новостей

Подписаться

Из-за чего всплывает Bad Request?

Есть 4 повода для возникновения ошибки сервера 400 Bad Request при попытке зайти на сайт:

  1. Некорректно настроенные HTTP-заголовки в запросе со стороны клиента. Некоторые приложения и сайты мониторят заголовки на предмет наличия в них чего-нибудь подозрительного. Если ваш запрос не соответствует ожиданиям сервера, то высока вероятность появления ошибки 400 (но это не всегда вина пользователя).
  2. Такой же сбой появляется, если клиент пытается загрузить на сервер файл слишком большого размера. Это происходит, потому что на большинстве сайтов есть ограничения по размеру загружаемых данных. Причем ограничение может быть как в 2 гигабайта, так и в 600 килобайт.
  3. Еще ошибка 400 появляется, когда пользователь пытается получить доступ к несуществующей странице. То есть в браузер банально ввели ссылку с опечаткой, некорректным доменом или поддоменом.
  4. Устаревшие или измененные куки-файлы. Сервер может воспринять подмену куки-файлов как попытку атаковать или воспользоваться дырой в безопасности. Поэтому такие запросы сходу блокируются.

Читайте также

Ошибка сервера 401

Ошибка 502 Bad Gateway Error

Исправляем ошибку 400 Bad Request на стороне клиента

Так как ошибка 400 в 99 случаев из 100 возникает на стороне клиента, начнем с соответствующих методов. Проверим все элементы, участвующие в передаче запроса со стороны клиента (браузера).

Проверяем адрес сайта

Банальщина, но необходимая банальщина. Перед тем как бежать куда-то жаловаться и предпринимать более серьезные шаги, повнимательнее взгляните на ссылку в адресной строке. Может, где-то затесалась опечатка или вы случайно написали большую букву вместо маленькой. Некоторые части адреса чувствительны к регистру. 

А еще стоит поискать запрашиваемую страницу через поисковик, встроенный в сайт. Есть вероятность, что конкретная страница куда-то переехала, но сервер не может показать подходящий HTTP-код в духе 404 Not Found. Если, конечно, сам сайт работает. 

Сбрасываем параметры браузера

Этот метод срабатывает, если сервер отказывается принимать запросы из-за «битых» куки или других данных. Дело в том, что сайт использует куки-файлы, чтобы хранить информацию о пользователе у него же в браузере. При входе конкретного человека на ресурс, он пытается распознать куки и сравнить информацию с той, что уже есть на сервере.

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

В зависимости от браузера процесс удаления куки-файлов может немного отличаться. В Chrome это работает так:

  • Открываем настройки браузера. 
  • Переходим в раздел «Конфиденциальность и безопасность».
  • Выбираем «Файлы cookie и другие данные».
  • Нажимаем на кнопку «Удалить все».Удаление кукис в Google Chrome

Для чистки cookies можно использовать стороннюю программу в духе CCleaner или CleanMyPC.

Загружаем файл подходящего размера

Если ошибка 400 Bad Request появляется при попытке загрузить на сайт какой-нибудь файл, то стоит попробовать загрузить файл поменьше. Иногда вебмастера ленятся грамотно настроить ресурс, и вместо понятного объяснения вроде «Загружаемые файлы не должны быть размером больше 2 мегабайт» люди получают Bad Request. Остается только гадать, какой там у них лимит. 

Устраняем проблемы, связанные с Windows и сторонним софтом

Помимо браузера, на работу сети могут влиять другие программные продукты (экраны, защищающие от «непонятных подключений»). И вирусы. Да и сама Windows может стать проблемой. Почти любой ее компонент. Поэтому надо бы проделать следующее:

  • Повторно установить NET.Framework. Желательно перед этим удалить предыдущую версию.
  • Установить какой-нибудь приличный антивирус (а лучше два) и запустить глубокую проверку систему. Возможно, подключению и входу на ресурс мешает вредоносная программа.
  • Если у вас уже установлен антивирус, то, наоборот, попробуйте его отключить. Иногда встроенные в них экраны проверки подключений блокируют работу браузера целиком или отдельных страниц. Лучше выдать браузеру больше прав на выполнение своих задач или установить антивирус, который более лояльно относится к установленному на компьютере софту.
  • Еще надо поменять параметры брандмауэра. Его можно разыскать в панели управления Windows. Там надо добавить в список исключений ваш браузер. Тогда брандмауэр не будет мешать подключению к запрашиваемому сайту.
  • Почистить Windows от программного мусора. Можно пройтись приложением CCleaner. 
  • Обновить драйверы для сетевых устройств. 
  • Обновить Windows или просканировать систему на наличие погрешностей в системных компонентах.

Ищем проблему на стороне сервера

Если что-то происходит на стороне ресурса, то это редко заканчивается ошибкой 400. Но все-таки есть несколько сценариев, при которых клиента обвиняют в сбое зря, а настоящая вина лежит на сервере. 

Проверяем требования к HTTP-заголовкам

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

Удаляем свежие обновления и плагины

Иногда ошибка 400 Bad Request появляется после обновления CMS или установки новых плагинов. Если у вас она появилась из-за этого, то наиболее логичное решение — откатиться до более ранней версии CMS и удалить все новые плагины. 

Главное, перед этим сделать резервную копию данных. И перед установкой обновлений тоже стоило бы.

Проверяем состояние базы данных

Некоторые сторонние расширения для того же WordPress получают полный доступ к ресурсу и имеют право вносить изменения даже в подключенную базу данных. Если после удаления свежих плагинов ошибка 400 никуда не исчезла и появляется у всех, кто пытается зайти на сайт, стоит проверить, в каком состоянии находится база данных. Нужно вручную проверить все записи на наличие подозрительных изменений, которые могли быть сделаны установленными расширениями.

Исправляем ошибки в коде и скриптах

Ничего из вышеперечисленного не помогло? Тогда осталось проверить свой код и работающие скрипты. Лучше провести дебаггинг вручную и не надеяться на помощь компьютера. Сделать копию приложения или сайта, потом пошагово проверить каждый отрезок кода в поисках ошибок. 

В крайнем случае придется кричать «полундра» и звать на помощь техподдержку хостинга. Возможно, возникли сложности на их стороне. Тогда вообще ничего не надо будет делать. Просто ждать, пока все исправят за вас. 

На этом все. Основные причины появления 400 Bad Request разобрали. Как ее лечить — тоже. Теперь дело за вами. Пользуйтесь полученной информацией, чтобы больше не пришлось мучиться в попытках зайти на нужный ресурс.

Вступайте в мою группу помощник программиста.
В ней мы обсуждаем программирование в 1С.

/// Как получить страницу сайта через http-запрос /// из 1с 8.3, 8.2   &НаКлиенте Процедура КакПолучитьСтраницуСайтаЧерезHttpЗапросНаКлиенте()   // В сети есть сайт http://example.com // Запросим содержимое его главной страницы.   // Подключаемся к сайту. Соединение = Новый HTTPСоединение( "example.com", // сервер (хост) 80, // порт, по умолчанию для http используется 80, для https 443 , // пользователь для доступа к серверу (если он есть) , // пароль для доступа к серверу (если он есть) , // здесь указывается прокси, если он есть , // таймаут в секундах, 0 или пусто - не устанавливать // защищенное соединение, если используется https );   // Получаем текст корневой страницы через GET-запрос. Запрос = Новый HTTPЗапрос("/"); // Если бы нужна была другая страница, мы бы указали, // например, "/about" или "/news".   Результат = Соединение.Получить(Запрос);   Сообщить("Нам вернули код: " + Результат.КодСостояния); // Что примерно означают коды результата запроса: // [100, 299] - хороший код возврата // [300, 399] - нас перенаправляют на другую страницу, // причём 302 - код постоянного перенаправления // [400, 499] - ошибка запроса // [500, 599] - ошибка сервера   // в теле результата запроса - текст обычной html страницы Сообщить("Тело результата: " + Результат.ПолучитьТелоКакСтроку());   КонецПроцедуры   /// Как обработать перенаправление в http-запросе /// из 1с 8.3, 8.2   &НаКлиенте Процедура КакОбработатьПеренаправлениеВHttpЗапросеНаКлиенте()   // Предположим, что мы хотим отправить поисковый http запрос // гуглу и получить от него страницу с результатами нашего // запроса.   // К примеру, будем искать по строке "работа программистом 1с в моём городе".   Соединение = Новый HTTPСоединение("www.google.com", 80);   Запрос = Новый HTTPЗапрос("/search?q=работа программистом 1с в моём городе"); Результат = Соединение.Получить(Запрос);   Сообщить("Нам вернули код " + Результат.КодСостояния);   Если Результат.КодСостояния = 302 Тогда Сообщить("Нас перенаправили на другую страницу."); Сообщить("Адрес этой страницы находится в заголовке результата Location."); Сообщить("Вот он: " + Результат.Заголовки.Получить("Location"));   // Воспользуемся вспомогательной функцией СтруктураURI, которая // сама вытаскивает из адреса имя хоста, порт и путь к ресурсу.   URI = СтруктураURI(Результат.Заголовки.Получить("Location"));   // Делаем новое подключение и get запрос.   Соединение = Новый HTTPСоединение(URI.Хост, URI.Порт); Запрос = Новый HTTPЗапрос(URI.ПутьНаСервере); Результат = Соединение.Получить(Запрос);   Сообщить("Нам вернули код " + Результат.КодСостояния);   // Сохраним тело ответа (это и есть наша страница с результатами // поиска) в виде htm файла и тут же покажем его пользователю.   КаталогДляЭкспериментов = КаталогДокументов() + "helpme1s.ru"; СоздатьКаталог(КаталогДляЭкспериментов); ФайлРезультатов = КаталогДляЭкспериментов + "test.htm";   Текст = Новый ЗаписьТекста(ФайлРезультатов, КодировкаТекста.UTF8); Текст.Записать(Результат.ПолучитьТелоКакСтроку()); Текст.Закрыть();   Сообщить("Результаты поиска сохранены в " + ФайлРезультатов);   ЗапуститьПриложение(ФайлРезультатов); КонецЕсли;   КонецПроцедуры   /// Как сохранить картинку с сайта через http-запрос /// из 1с 8.3, 8.2   &НаКлиенте Процедура КакСохранитьКартинкуСайтаЧерезHttpЗапросНаКлиенте()   // Запрашивать через http можно не только html-страницы, // но и другие объекты, доступные нам через http, // например, картинки.   // Сохраним на диск и покажем пользователю картинку, которая // размещена в интернете по адресу: // thumb7.shutterstock.com/display_pic_with_logo/1014806/270790184/ // stock-photo-summer-holidays-background-sea-background-270790184.jpg   Соединение = Новый HTTPСоединение("thumb7.shutterstock.com", 80);   // Get-запрос к ресурсу на сервере. Запрос = Новый HTTPЗапрос("/display_pic_with_logo/1014806/270790184/" + "stock-photo-summer-holidays-background-sea-background-270790184.jpg"); Результат = Соединение.Получить(Запрос);   Сообщить("Нам вернули код " + Результат.КодСостояния);   // Сама картинка - уже в теле ответа, осталось // только записать её в файл на диск в виде двоичных данных.   КаталогДляЭкспериментов = КаталогДокументов() + "helpme1s.ru"; СоздатьКаталог(КаталогДляЭкспериментов); ФайлКартинки = КаталогДляЭкспериментов + "test.jpg";   // Записываем картинку на диск. Результат.ПолучитьТелоКакДвоичныеДанные().Записать(ФайлКартинки);   Сообщить("Сохранили картинку по адресу " + ФайлКартинки);   // Покажем картинку пользователю. ЗапуститьПриложение(ФайлКартинки);   КонецПроцедуры   /// Как послать защищенный https запрос к серверу из 1с 8.3, 8.2   &НаКлиенте Процедура КакПослатьЗащищенныйHttpsЗапросКСерверуНаКлиенте()   // Получим код страницы https://ya.ru // Так как для доступа к ней используется защищенный // протокол https - нам нужно заполнить последний // параметр при соединении с сервером.   Соединение = Новый HTTPСоединение( "ya.ru", // сервер (хост) 443, // порт, по умолчанию для http используется 80, для https 443 , // пользователь для доступа к серверу (если он есть) , // пароль для доступа к серверу (если он есть) , // здесь указывается прокси, если он есть , // таймаут в секундах, 0 или пусто - не устанавливать Новый ЗащищенноеСоединениеOpenSSL() );   // Получаем текст корневой страницы через GET-запрос. Запрос = Новый HTTPЗапрос("/"); // Если бы нужна была другая страница, мы бы указали, // например, "/about" или "/news".   Результат = Соединение.Получить(Запрос); Сообщить(Результат.КодСостояния); Сообщить(Результат.ПолучитьТелоКакСтроку());   КонецПроцедуры   /// Как установить заголовки http-запроса из 1с 8.3, 8.2   &НаКлиенте Процедура КакУстановитьЗаголовкиHttpЗапросаНаКлиенте()   // Возьмём чисто гипотетический пример.   // Нам нужно послать запрос к http://example.com/, // передав ему в куках (cookie) session=231. // Также мы будем передадим в запросе поле keep-alive, // чтобы сервер не закрывал наше соединений к нему // для повторых запросов.   // За всё это отвечают заголовки запроса.   Заголовки = Новый Соответствие; Заголовки.Вставить("Cookie", "session=231"); Заголовки.Вставить("Connection", "keep-alive");   // Подключаемся к сайту. Соединение = Новый HTTPСоединение("example.com");   // Получаем текст корневой страницы через GET-запрос. Запрос = Новый HTTPЗапрос("/", Заголовки); // Если бы нужна была другая страница, мы бы указали, // например, "/about" или "/news".   Результат = Соединение.Получить(Запрос);   КонецПроцедуры   /// Как указать прокси для http-запроса из 1с 8.3, 8.2   &НаКлиенте Процедура КакУказатьПроксиДляHttpЗапросаНаКлиенте()   // Если для соединения с интернетом используется прокси, // его нужно указывать так.   ПроксиСервер = Новый ИнтернетПрокси; // авторизация ПроксиСервер.Пользователь = "Vova"; ПроксиСервер.Пароль = "123"; // прокси сервер прописывается для каждого протокола отдельно ПроксиСервер.Установить("http", "192.168.0.1", "8080"); ПроксиСервер.Установить("https", "192.168.0.1", "6547");   // Созданный объект указываем при http соединении.   Соединение = Новый HTTPСоединение("example.com",,,, ПроксиСервер);   КонецПроцедуры   /// Как послать post-запрос через http из 1с 8.3, 8.2   &НаКлиенте Процедура КакПослатьPostЗапросНаКлиенте()   // Post-запрос отличается от Get-запроса только наличием // тела запроса.   // То есть этот тот же самый HTTPЗапрос, но у которого  // вызыван метод УстановитьТелоИзСтроки. // И это тело уже может быть и просто текстом, и текстом // в формате xml, json, soap и так далее.   // В качестве большого примера рассмотрим фрагмент // авторизации на сайте 1с, там используются и get // и post запросы.   // Откуда мы узнали как и когда посылать какие запросы? // Мы подсмотрели их у браузера (в Хроме нажмите F12, вкладка Network), // а также использовали беплатный инструмент Fiddler // для отладки и мониторинга http запросов.   // Если бы мы писали рабочий код - нам понадобилось // всего несколько соединений с сервером, которые // мы бы не закрывали. Но в учебных целях будем // писать максимально просто ("тупо").   // 1. Первым делом - посылаем get-запрос к // https://releases.1c.ru/total   Соединение = Новый HTTPСоединение("releases.1c.ru",,,,,, Новый ЗащищенноеСоединениеOpenSSL()); Запрос = Новый HTTPЗапрос("/total"); Результат = Соединение.Получить(Запрос);   // В куках нам должны вернуть идентификатор сессии. Куки = Результат.Заголовки.Получить("Set-Cookie"); // Он идёт первым параметром и отделён от остальных // частей точкой с запятой. Куки = СтрЗаменить(Куки, ";", Символы.ПС); ИдентификаторСессии1 = СтрПолучитьСтроку(Куки, 1);   Сообщить(ИдентификаторСессии1);   // 2. В результате первого запроса нас перенаправили // на другую страницу, перейдём на неё новым get-запросом. Перенаправление = Результат.Заголовки.Получить("Location");   Сообщить("Код возврата " + Результат.КодСостояния); Сообщить("Нас перенаправили на " + Перенаправление);   // При помощи служебной функции СтруктураURI разберём // новый адрес на части.   URI = СтруктураURI(Перенаправление);   Соединение = Новый HTTPСоединение(URI.Хост, URI.Порт,,,,, Новый ЗащищенноеСоединениеOpenSSL()); Запрос = Новый HTTPЗапрос(URI.ПутьНаСервере); Результат = Соединение.Получить(Запрос);   // В куках нам вернули второй идентификатор. Куки = Результат.Заголовки.Получить("Set-Cookie"); Куки = СтрЗаменить(Куки, ";", Символы.ПС); ИдентификаторСессии2 = СтрПолучитьСтроку(Куки, 1);   Сообщить(ИдентификаторСессии2);   // 3. В результате предыдущего Get-запроса в теле нам вернули // страницу авторизации, вытащим из формы авторизации значения // параметров name="lt", name="execution" и name="_eventId", // чтобы затем сформировать код приглашения на сайт.   ltValue = ""; executionValue = ""; _eventIdValue = "";   Текст = Новый ТекстовыйДокумент; Текст.УстановитьТекст(Результат.ПолучитьТелоКакСтроку()); Для Индекс = 0 По Текст.КоличествоСтрок() Цикл Строка = Текст.ПолучитьСТроку(Индекс); Если Найти(Строка, "name=""lt""") > 0 Тогда ltValue = ВытащитьЗначениеИзСтроки(Строка); ИначеЕсли Найти(Строка, "name=""execution""") > 0 Тогда executionValue = ВытащитьЗначениеИзСтроки(Строка); ИначеЕсли Найти(Строка, "name=""_eventId""") > 0 Тогда _eventIdValue = ВытащитьЗначениеИзСтроки(Строка); КонецЕсли; КонецЦикла;   Сообщить(ltValue); Сообщить(executionValue); Сообщить(_eventIdValue);   // Для формирования кода приглашения нам понадобится // наш логин и пароль от ИТС.    ЛогинИТС = ""; ПарольИТС = "";   Если ЛогинИТС = "" Или ПарольИТС = "" Тогда Сообщить("Для продолжения укажите в коде логин и пароль от ИТС."); Возврат; КонецЕсли;   КодПриглашения = "inviteCode=" + "&lt=" + ltValue + "&execution=" + executionValue + "&_eventId=" + _eventIdValue + "&username=" + ЛогинИТС + "&password=" + ПарольИТС;   // 4. Наконец, посылаем Post-запрос, вкладывая в тело запроса // код приглашения, а куках указыаем второй идентификатор сессии.    Ресурс = "/login;" + ИдентификаторСессии2 + "?service=https%3A%2F%2Fusers.v8.1c.ru%2Fdistribution%2Fpublic%2Fsecurity_check%3B" + ИдентификаторСессии1;   Соединение = Новый HTTPСоединение("login.1c.ru",,,,,, Новый ЗащищенноеСоединениеOpenSSL());   Заголовки = Новый Соответствие; Заголовки.Вставить("Cookie", ИдентификаторСессии2); Заголовки.Вставить("Content-Type", "application/x-www-form-urlencoded;");   Запрос = Новый HTTPЗапрос(Ресурс, Заголовки); Запрос.УстановитьТелоИзСтроки(КодПриглашения);   Результат = Соединение.ОтправитьДляОбработки(Запрос);   Сообщить("Нам вернули код " + Результат.КодСостояния); Перенаправление = Результат.Заголовки.Получить("Location"); Сообщить("И перенаправили на " + Перенаправление);   // 5. В завершении авторизации переходим на следующую // страницу, используя первый идентификатор сессии.   URI = СтруктураURI(Перенаправление);   Соединение = Новый HTTPСоединение(URI.Хост, URI.Порт,,,,, Новый ЗащищенноеСоединениеOpenSSL());   Заголовки = Новый Соответствие; Заголовки.Вставить("Cookie", ИдентификаторСессии1);   Запрос = Новый HTTPЗапрос(URI.ПутьНаСервере, Заголовки); Результат = Соединение.Получить(Запрос);   Сообщить("Нам вернули " + Результат.КодСостояния); Перенаправление = Результат.Заголовки.Получить("Location"); Сообщить("И окончательно перенаправили на " + Перенаправление);   // Авторизация окончена, теперь можем запрашивать любые // страницы сайта, используя первый идентификатор сессии.   КонецПроцедуры   &НаКлиенте Функция СтруктураURI(Знач СтрокаURI) Экспорт   СтрокаURI = СокрЛП(СтрокаURI);   // схема Схема = ""; Позиция = Найти(СтрокаURI, "://"); Если Позиция > 0 Тогда Схема = НРег(Лев(СтрокаURI, Позиция - 1)); СтрокаURI = Сред(СтрокаURI, Позиция + 3); КонецЕсли;   // строка соединения и путь на сервере СтрокаСоединения = СтрокаURI; ПутьНаСервере = ""; Позиция = Найти(СтрокаСоединения, "/"); Если Позиция > 0 Тогда ПутьНаСервере = Сред(СтрокаСоединения, Позиция + 1); СтрокаСоединения = Лев(СтрокаСоединения, Позиция - 1); КонецЕсли;   // информация пользователя и имя сервера СтрокаАвторизации = ""; ИмяСервера = СтрокаСоединения; Позиция = Найти(СтрокаСоединения, "@"); Если Позиция > 0 Тогда СтрокаАвторизации = Лев(СтрокаСоединения, Позиция - 1); ИмяСервера = Сред(СтрокаСоединения, Позиция + 1); КонецЕсли;   // логин и пароль Логин = СтрокаАвторизации; Пароль = ""; Позиция = Найти(СтрокаАвторизации, ":"); Если Позиция > 0 Тогда Логин = Лев(СтрокаАвторизации, Позиция - 1); Пароль = Сред(СтрокаАвторизации, Позиция + 1); КонецЕсли;   // хост и порт Хост = ИмяСервера; Порт = ""; Позиция = Найти(ИмяСервера, ":"); Если Позиция > 0 Тогда Хост = Лев(ИмяСервера, Позиция - 1); Порт = Сред(ИмяСервера, Позиция + 1); КонецЕсли;   Результат = Новый Структура; Результат.Вставить("Схема", Схема); Результат.Вставить("Логин", Логин); Результат.Вставить("Пароль", Пароль); Результат.Вставить("ИмяСервера", ИмяСервера); Результат.Вставить("Хост", Хост); Результат.Вставить("Порт", ?(Порт <> "", Число(Порт), Неопределено)); Результат.Вставить("ПутьНаСервере", ПутьНаСервере);   Возврат Результат;   КонецФункции   &НаКлиенте Функция ВытащитьЗначениеИзСтроки(Строка)   Позиция2 = СтрДлина(Строка); Пока Позиция2 > 1 Цикл Если Сред(Строка, Позиция2, 1) = """" Тогда Прервать; КонецЕсли; Позиция2 = Позиция2 - 1; КонецЦикла;   Позиция1 = Позиция2 - 1; Пока Позиция1 > 1 Цикл Если Сред(Строка, Позиция1, 1) = """" Тогда Прервать; КонецЕсли; Позиция1 = Позиция1 - 1; КонецЦикла;   Возврат Сред(Строка, Позиция1 + 1, Позиция2 - Позиция1 - 1);   КонецФункции   /// Скачать и выполнить эти примеры на компьютере

Ошибка 400 Bad Request – это код ответа HTTP, который означает, что сервер не смог обработать запрос, отправленный клиентом из-за неверного синтаксиса. Подобные коды ответа HTTP отражают сложные взаимоотношения между клиентом, веб-приложением, сервером, а также зачастую сразу несколькими сторонними веб-сервисами. Из-за этого поиск причины появления ошибки может быть затруднён даже внутри контролируемой среды разработки.

В этой статье мы разберём, что значит ошибка 400 Bad Request (переводится как «Неверный запрос»), и как ее исправить

  • На стороне сервера или на стороне клиента?
  • Начните с тщательного резервного копирования приложения
  • Диагностика ошибки 400 Bad Request
  • Исправление проблем на стороне клиента
    • Проверьте запрошенный URL
    • Очистите соответствующие куки
    • Загрузка файла меньшего размера
    • Выйдите и войдите
  • Отладка на распространённых платформах
    • Откатите последние изменения
    • Удалите новые расширения, модули или плагины
    • Проверьте непреднамеренные изменения в базе данных
  • Поиск проблем на стороне сервера
    • Проверка на неверные заголовки HTTP
    • Просмотрите логи
  • Отладьте код приложения или скриптов

Все коды ответа HTTP из категории 4xx считаются ошибками на стороне клиента. Несмотря на это, появление ошибки 4xx не обязательно означает, что проблема как-то связана с клиентом, под которым понимается веб-браузер или устройство, используемое для доступа к приложению. Зачастую, если вы пытаетесь диагностировать проблему со своим приложением, можно сразу игнорировать большую часть клиентского кода и компонентов, таких как HTML, каскадные таблицы стилей (CSS), клиентский код JavaScript и т.п. Это также применимо не только к сайтам. Многие приложения для смартфонов, которые имеют современный пользовательский интерфейс, представляют собой веб-приложения.

С другой стороны, ошибка 400 Bad Request означает, что запрос, присланный клиентом, был неверным по той или иной причине. Пользовательский клиент может попытаться загрузить слишком большой файл, запрос может быть неверно сформирован, заголовки HTTP запроса могут быть неверными и так далее.

Мы рассмотрим некоторые из этих сценариев (и потенциальные решения) ниже. Но имейте в виду: мы не можем однозначно исключить ни клиент, ни сервер в качестве источника проблемы. В этих случаях сервер является сетевым объектом, генерирующим ошибку 400 Bad Request и возвращающим её как код ответа HTTP клиенту, но возможно именно клиент ответственен за возникновение проблемы.

Важно сделать полный бэкап вашего приложения, базы данных и т.п. прежде, чем вносить какие-либо правки или изменения в систему. Ещё лучше, если есть возможность создать полную копию приложения на дополнительном промежуточном сервере, который недоступен публично.

Подобный подход обеспечит чистую тестовую площадку, на которой можно отрабатывать все возможные сценарии и потенциальные изменения, чтобы исправить или иную проблему без угрозы безопасности или целостности вашего «живого» приложения.

Ошибка 400 Bad Request означает, что сервер (удалённый компьютер) не может обработать запрос, отправленный клиентом (браузером), вследствие проблемы, которая трактуется сервером как проблема на стороне клиента.

Существует множество сценариев, в которых ошибка 400 Bad Request может появляться в приложении. Ниже представлены некоторые наиболее вероятные случаи:

  • Клиент случайно (или намеренно) отправляет информацию, перехватываемую маршрутизатором ложных запросов. Некоторые веб-приложения ищут особые заголовки HTTP, чтобы обрабатывать запросы и удостовериться в том, что клиент не предпринимает ничего зловредного. Если ожидаемый заголовок HTTP не найден или неверен, то ошибка 400 Bad Request – возможный результат.
  • Клиент может загружать слишком большой файл. Большинство серверов или приложений имеют лимит на размер загружаемого файла, Это предотвращает засорение канала и других ресурсов сервера. Во многих случаях сервер выдаст ошибку 400 Bad Request, когда файл слишком большой и поэтому запрос не может быть выполнен.
  • Клиент запрашивает неверный URL. Если клиент посылает запрос к неверному URL (неверно составленному), это может привести к возникновению ошибки 400 Bad Request.
  • Клиент использует недействительные или устаревшие куки. Это возможно, так как локальные куки в браузере являются идентификатором сессии. Если токен конкретной сессии совпадает с токеном запроса от другого клиента, то сервер/приложение может интерпретировать это как злонамеренный акт и выдать код ошибки 400 Bad Request.

Устранение ошибки 400 Bad Request (попробуйте позже) лучше начать с исправления на стороне клиента. Вот несколько советов, что следует попробовать в браузере или на устройстве, которые выдают ошибку.

Наиболее частой причиной ошибки 400 Bad Request является банальный ввод некорректного URL. Доменные имена (например, internet-technologies.ru) нечувствительны к регистру, поэтому ссылка, написанная в смешанном регистре, такая как interNET-technologies.RU работает так же, как и нормальная версия в нижнем регистре internet-technologies.ru. Но части URL, которые расположены после доменного имени, чувствительными к регистру. Кроме случаев, когда приложение/сервер специально осуществляет предварительную обработку всех URL и переводит их в нижний регистр перед исполнением запроса.

Важно проверять URL на неподходящие специальные символы, которых в нем не должно быть. Если сервер получает некорректный URL, он выдаст ответ в виде ошибки 400 Bad Request.

Одной из потенциальных причин возникновения ошибки 400 Bad Request являются некорректные или дублирующие локальные куки. Файлы куки в HTTP – это небольшие фрагменты данных, хранящиеся на локальном устройстве, которые используются сайтами и веб-приложениями для «запоминания» конкретного браузера или устройства. Большинство современных веб-приложений использует куки для хранения данных, специфичных для браузера или пользователя, идентифицируя клиента и позволяя делать следующие визиты быстрее и проще.

Но куки, хранящие информацию сессии о вашем аккаунте или устройстве, могут конфликтовать с другим токеном сессии от другого пользователя, выдавая кому-то из вас (или вам обоим) ошибку 400 Bad Request.

В большинстве случаев достаточно рассматривать только ваше приложение в отношении файлов куки, которые относятся к сайту или веб-приложению, выдающему ошибку 400 Bad Request.

Куки хранятся по принципу доменного имени веб-приложения, поэтому можно удалить только те куки, которые соответствуют домену сайта, сохранив остальные куки не тронутыми. Но если вы не знакомы с ручным удалением определённых файлов куки, гораздо проще и безопаснее очистить сразу все файлы куки.

Это можно сделать разными способами в зависимости от браузера, который вы используете:

  • Google Chrome;
  • Internet Explorer;
  • Microsoft Edge;
  • Mozilla Firefox;
  • Safari.

Если вы получаете ошибку 400 Bad Request при загрузке какого-либо файла, попробуйте корректность работы на меньшем по размеру файле, Это включает в себя и «загрузки» файлов, которые не загружаются с вашего локального компьютера. Даже файлы, отправленные с других компьютеров, считаются «загрузками» с точки зрения веб-сервера, на котором работает ваше приложение.

Попробуйте выйти из системы и войти обратно. Если вы недавно очистили файлы куки в браузере, это приводит к автоматическому выходу из системы при следующей загрузке страницы. Попробуйте просто войти обратно, чтобы посмотреть, заработала ли система корректно.

Также приложение может столкнуться с проблемой, связанной с вашей предыдущей сессией, являющейся лишь строкой, которую сервер посылает клиенту, чтобы идентифицировать клиента при будущих запросах. Как и в случае с другими данными, токен сессии (или строка сессии) хранится локально на вашем устройстве в файлах куки и передаётся клиентом на сервер при каждом запросе. Если сервер решает, что токен сессии некорректен или скомпрометирован, вы можете получить ошибку 400 Bad Request.

В большинстве веб-приложений выход повторный вход приводит к перегенерации локального токена сессии.

Если вы используете на сервере распространённые пакеты программ, которые выдают ошибку 400 Bad Request, изучите стабильность и функциональность этих платформ. Наиболее распространённые системы управления контентом, такие как WordPress, Joomla! и Drupal, хорошо протестированы в своих базовых версиях. Но как только вы начинаете изменять используемые ими расширения PHP, очень легко спровоцировать непредвиденные проблемы, которые выльются в ошибку 400 Bad Request.

Если вы обновили систему управления контентом непосредственно перед появлением ошибки 400 Bad Request, рассмотрите возможность отката к предыдущей версии, которая была установлена, как самый быстрый и простой способ убрать ошибку 400 bad request.

Аналогично, любые расширения или модули, которые были обновлены, могут вызывать ошибки на стороне сервера, поэтому откат к предыдущим версиям этих расширений также может помочь.

Но в некоторых случаях CMS не предоставляют возможности отката к предыдущим версиям. Так обычно происходит с популярными платформами, поэтому не бойтесь, если вы не можете найти простой способ вернуться к использованию старой версии той или иной программной платформы.

В зависимости от конкретной CMS, которую использует приложение, имена этих компонентов будут различаться. Но во всех системах они служат одной и той же цели: улучшение возможностей платформы относительно её стандартной функциональности.

При этом имейте в виду, что расширения могут так или иначе получать полный контроль над системой, вносить изменения в код PHP, HTML, CSS, JavaScript или базу данных. Поэтому мудрым решением может быть удаление любых новых расширений, которые были недавно добавлены.

Даже если удалили расширение через панель управления CMS, это не гарантирует, что внесенные им изменения были полностью отменены. Это касается многих расширений WordPress, которым предоставляется полный доступ к базе данных.

Расширение может изменить записи в базе данных, которые «не принадлежат» ему, а созданы и управляются другими расширениями (или даже самой CMS). В подобных случаях модуль может не знать, как откатить назад изменения, внесенные в записи базы данных.

Я лично сталкивался с такими случаями несколько раз. Поэтому лучшим путём будет открыть базу данных и вручную просмотреть таблицы и записи, которые могли быть изменены расширением.

Если вы уверены, что ошибка 400 Bad Request не связана с CMS, вот некоторые дополнительные советы, которые могут помочь найти проблему на стороне сервера.

Ошибка, которую вы получаете от приложения, является результатом недостающих или некорректных специальных заголовков HTTP, которые ожидает получить приложение или сервер. В подобных случаях нужно проанализировать заголовки HTTP, которые отправляются на сторону сервера.

Почти любое веб-приложение будет вести логи на стороне сервера. Они представляют собой историю того, что делало приложение. Например, какие страницы были запрошены, к каким серверам оно обращалось, какие результаты предоставлялись из базы данных и т.п.

Логи сервера относятся к оборудованию, на котором выполняется приложение, и зачастую представляют собой детали о статусе подключённых сервисов или даже о самом сервере. Поищите в интернете “логи [ИМЯ_ПЛАТФОРМЫ]”, если вы используете CMS, или “логи [ЯЗЫК_ПРОГРАММИРОВАНИЯ]” и “логи [ОПЕРАЦИОННАЯ_СИСТЕМА]”, если у вас собственное приложение, чтобы получить подробную информацию по поиску логов.

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

Создайте копию всего приложения на локальном устройстве для разработки и пошагово повторите тот сценарий, который приводил к возникновению ошибки 400 Bad Request. А затем просмотрите код приложения в тот момент, когда что-то пойдёт не так.

Независимо от причины возникновения ошибки, даже если вам удалось исправить её в этот раз, появление в вашем приложении такой проблемы — это сигнал для того, чтобы внедрить инструмент обработки ошибок, который поможет автоматически обнаруживать их и оповещать в момент возникновения.

   KuznecovvIvan

21.11.22 — 14:07

Пытаюсь сделать JSON запрос, он выдает ошибку 400. Вроде все правильно сделал. Сервер поднял на IIS. Причем если открываю через браузер, то обращение происходит к HTTP-сервису. Но если пытаюсь сделать этим кодом, то ошибка 400.  Высылаю код

Функция ОтправитьHTTPЗапрос(СтруктураОтправки)

        Логин = СтруктураОтправки.Логин;

    Пароль = СтруктураОтправки.Пароль;        

    Сервер = СтруктураОтправки.Сервер;     

    Порт = СтруктураОтправки.Порт;

    АдресРесурса = СтруктураОтправки.АдресРесурса;

    СтрокаJSON =  СтруктураОтправки.СтрокаJSON;

    МетодСервиса = СтруктураОтправки.МетодСервиса;

    
    #Если Клиент  Тогда

        SSL = Новый ЗащищенноеСоединениеOpenSSL(Новый СертификатКлиентаWindows(СпособВыбораСертификатаWindows.Выбирать),Новый СертификатыУдостоверяющихЦентровWindows());

    #Иначе

        SSL = Новый ЗащищенноеСоединениеOpenSSL(Неопределено,Неопределено);

    #КонецЕсли

    
    HTTPСоединение = Новый HTTPСоединение(Сервер,Порт,Логин,Пароль,,,SSL);// // не забыть вернуть Кузнецов ИВ

    
    HTTPЗапрос = новый HTTPЗапрос(МетодСервиса);

    HTTPЗапрос.АдресРесурса = АдресРесурса;

    HTTPЗапрос.УстановитьТелоИзСтроки(СтрокаJSON, КодировкаТекста.UTF8 ,ИспользованиеByteOrderMark.НеИспользовать);//

    HTTPЗапрос.Заголовки.Вставить(«Content-type», «application/json-rpc»);

    
    //HTTPЗапрос.Заголовки.Вставить(«Content-type», «application/x-www-form-urlencoded»);

    ДокументJSON = HTTPЗапрос.ПолучитьТелоКакСтроку();

    ваплво = ПрочитатьСтрокуJSON(ДокументJSON);    

    
    Попытка

        РезультатВыполнения = HTTPСоединение.ВызватьHTTPМетод(МетодСервиса,HTTPЗапрос);

    Исключение

        Сообщить(ОписаниеОшибки());

    КонецПопытки;  

    Возврат РезультатВыполнения;

КонецФункции

   KuznecovvIvan

5 — 21.11.22 — 14:33

(4) Да это мусор в переменных следующее:

    СтруктураОтправки = новый Структура;

    СтруктураОтправки.Вставить(«Логин», «»); //

    СтруктураОтправки.Вставить(«Пароль», «»);

    СтруктураОтправки.Вставить(«Сервер»,»192.168.65.140″);  

    СтруктураОтправки.Вставить(«Порт», 443);

    СтруктураОтправки.Вставить(«АдресРесурса», «https://192.168.65.140/Working_KuznecovIV/hs/APIService/V1/SoglasovanieObmenDO»);        

    СтруктураОтправки.Вставить(«СтрокаJSON», ДокументJSON);

    СтруктураОтправки.Вставить(«МетодСервиса», «POST»);

Если я пытаюсь адрес ввести в браузере в поисковую строку, то он выполняет метод GET HTTP-сервиса. И авторизация там норм проходит

Ошибка при авторизации в 1С.Маркировка МДПЛ по сертификату: при выполнении POST-запроса по адресу /api/v1/auth, error_code, api.authentication.error, error_description. Проверьте аутентификационные данные

Описание ошибки:
При попытке выполнить авторизацию на api-сервер Маркировки из модуля МДЛП в 1С 8:
Ошибка при выполнении POST-запроса по адресу /api/v1/auth
[400] Запрос не может быть исполнен.
{«error_code»:»api.authentication.error»,»error_description»:»Ошибка при
выполнении операции: Проверьте аутентификационные данные»}

Найденные решения:

В модуле обмена 1С.Маркировка МДЛП после нажатия на кнопку «Выполнить обмен» и выбора сертификата для подписи при попытке авторизации возникает окно «Не удалось подписать данные» с содержанием ошибки, представленным выше.

Нажатие на изображении увеличит его
1С 8 как исправить ошибку Ошибка при выполнении POST-запроса по адресу /api/v1/auth [400] Запрос не может быть исполнен.<br>
Рис.1. Момент возникновения ошибки «Ошибка при выполнении POST-запроса по адресу . /api/v1/auth. Проверьте аутентификационные данные»

Проблема исходя из описания самой ошибки заключается в том, что какие-то данные для подключения не подходят. На этом этапе обычно в промышленном контуре на сайте mdlp.crpt.ru, уже должна быть добавлена «Учётная система» в разделе «Администрирование». Поэтому первым делом необходимо проверить заполнение элемента справочника «Организации МДЛП» для «Собственной организации». Реквизит «Регистрационный номер участника» должен быть использован из профиля организации. А реквизиты «Идентификатор клиента» и «Секретный код» должны совпадать с данными раздела «Администрирование. Учетные системы» кабинета МДЛП для вашей организации. Для API «Промышленной системы» и «Тестовая система МДЛП («Песочница») значение реквизитов отличаются. Это необходимо учитывать и изменить при необходимости.

Нажатие на изображении увеличит его
1С 8 как исправить {"error_code":"api.authentication.error","error_description":"Ошибка при выполнении операции: Проверьте аутентификационные данные"}
Рис. 2. Пример с сайта infostart корректности заполнения полей настройки в 1С по данным учетной системы в кабинете МДЛП

Если будут перепутаны и не туда введены какие-либо из трех идентификаторов (рег. номер участника, идентификатор клиента или секретный код), то будет возникать ошибка. Так же если выбран не верный «Адрес API» в «Настройки и справочники» модуля МДЛП в 1С 8. В данном исходно был установлено значение «api.sb.mdlp.crpt.ru». Это не подходило.

Нажатие на изображении увеличит его
1C 8 Ошибка при выполнении POST-запроса по адресу /api/v1/auth [400] Запрос не может быть исполнен. {"error_code":"api.authentication.error","error_description":"Ошибка при выполнении операции: Проверьте аутентификационные данные"}
Рис. 3. Выбор адреса API в настройках модуля МДЛП в базе 1С 8.

После выбора значения «Промышленная система» подпись данных стала выполняться без возникновения ошибки.

Нажатие на изображении увеличит его

Рис. 4. Значение адреса API после выбора значения «Промышленная система».

Оцените, помогло ли Вам предоставленное описание решения ошибки?




© www.azhur-c.ru 2014-2020. Все права защищены. Использование текстов и изображений с данной страницы без письменного разрешения владельца запрещено. При использовании материалов с данной страницы обязательно указание ссылки на данную страницу.

20-09-2022

Журавлев А.С.
(Сайт azhur-c.ru)

Здравствуйте.
Это мой первый вопрос здесь. Возможно, найдется, кто понимает, в чём тут дело. Спасибо.
———————————————————————————————
Есть веб-сервис и общая команда. В общей команде код:

Попытка
        ВСОпределение = Новый WSОпределения("http://192.168.___.__/t10/ws/OD.1cws?wsdl";); //#1
        ВСервер = ВСОпределение.Сервисы.Получить("OD","OD");
        ВТочкаВхода = ВСервер.ТочкиПодключения.Получить("ODSoap");
        ВТОперация = ВТочкаВхода.Интерфейс.Операции.Получить("Sinhron");
        Данные = Новый ХранилищеЗначения("Некие данные",Новый СжатиеДанных(9));
        ДанныеXDTO = ВСОпределение.ФабрикаXDTO.Создать(ВТОперация.Параметры.Получить("Dan").Тип,Данные);
        ВСПрокси = Новый WSПрокси(ВСОпределение,"OD","OD","ODSoap");
        Ответ = ВСПрокси.Синхронизация(ДанныеXDTO);    
        Возврат Истина;    
    Исключение
        Сообщить(ОписаниеОшибки());
        Возврат Ложь;    
    КонецПопытки;

При нажатии на кнопку ВыполнитьСинхронизацию сначала было все хорошо, т.е. выполнение шло по ветке Попытка, до Ответ доходило точно, в ветку Исключение выполнение не переходило.

Но затем, не понятно почему, при очередном тестировании кнопки с общей командой, сразу после прохождения строки кода #1 выполнение стало переходить к Исключению и в
результате — ошибка (указывает именно на эту строку кода (выше) и код ошибки 400).

(1с и Apache2.2 переустановил — не помогло)

При этом базу в браузере вижу, xml-файл тоже.
————————————
Примерно в момент возникновения этой ошибки началось следующее: даже если база нигде не открыта (ни в браузере, ни на ПК), выдается сообщение: “Достигнуто предельное количество подключений к ИБ”. Чтобы выходить из этой ситуации приходится часто чистить кэш и останавливать сервер.

Что это может быть? Как исправить?

5 / 5 / 5

Регистрация: 17.12.2013

Сообщений: 202

1

07.06.2016, 12:43. Показов 15793. Ответов 3


Студворк — интернет-сервис помощи студентам

Добрый день
Есть запрос, который хотим отправлять через http

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

1C
1
ВЫБРАТЬ НАЧАЛОПЕРИОДА(ХозрасчетныйДвиженияССубконто.Период, ДЕНЬ) КАК Дата,ГОД(ХозрасчетныйДвиженияССубконто.Период) КАК Год,МЕСЯЦ(ХозрасчетныйДвиженияССубконто.Период) КАК Месяц,ХозрасчетныйДвиженияССубконто.Регистратор.Номер КАК Номер,ХозрасчетныйДвиженияССубконто.СчетДт КАК Счет,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код =000000010“ ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт1 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт2 КОНЕЦ КАК Подразделение,ВЫБОР ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1 КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код =000000010“ ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт2 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт1 КОНЕЦ КАК СтатьяЗатрат,ХозрасчетныйДвиженияССубконто.СубконтоКт1 КАК Контрагент,ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоКт1) КАК КонтрагентПредставление,ХозрасчетныйДвиженияССубконто.СубконтоДт3 КАК НомГруппа,ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоДт3) КАК НомГруппаПредставление,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL  ТОГДА -ХозрасчетныйДвиженияССубконто.Сумма ИНАЧЕ -ХозрасчетныйДвиженияССубконто.ВалютнаяСуммаКт КОНЕЦ КАК Сумма,ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL ТОГДА Константы.ВалютаУправленческогоУчета ИНАЧЕ ХозрасчетныйДвиженияССубконто.ВалютаКт КОНЕЦ КАК Валюта,-ХозрасчетныйДвиженияССубконто.Сумма КАК Сумма1,ХозрасчетныйДвиженияССубконто.Регистратор КАК Регистратор,ХозрасчетныйДвиженияССубконто.Содержание КАК Содержание ИЗ РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто(ДАТАВРЕМЯ(2015, 10, 01), ДАТАВРЕМЯ(2015, 10, 31), СчетДт.Код =91“ ИЛИ СчетДт.Код =92“ ИЛИ СчетДт.Код =93,, ) КАК ХозрасчетныйДвиженияССубконто, Константы КАК Константы

При выполнении получаю ошибку
Invoke-RestMethod : Bad Request — Invalid URL
HTTP Error 400. The request URL is invalid.

В чем может быть ошибка?

Добавлено через 3 минуты
Также пробуем вместо двойных кавычек использовать !!! и вместо запятых %%%,

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

1C
1
ВЫБРАТЬ НАЧАЛОПЕРИОДА(ХозрасчетныйДвиженияССубконто.Период, ДЕНЬ) КАК Дата%%% ГОД(ХозрасчетныйДвиженияССубконто.Период) КАК Год%%% МЕСЯЦ(ХозрасчетныйДвиженияССубконто.Период) КАК Месяц%%% ХозрасчетныйДвиженияССубконто.Регистратор.Номер КАК Номер%%% ХозрасчетныйДвиженияССубконто.СчетДт КАК Счет%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код = !!!000000010!!! ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт1 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт2 КОНЕЦ КАК Подразделение%%% ВЫБОР ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1 КОГДА ХозрасчетныйДвиженияССубконто.ВидСубконтоДт1.Код = !!!000000010!!! ТОГДА ХозрасчетныйДвиженияССубконто.СубконтоДт2 ИНАЧЕ ХозрасчетныйДвиженияССубконто.СубконтоДт1 КОНЕЦ КАК СтатьяЗатрат%%% ХозрасчетныйДвиженияССубконто.СубконтоКт1 КАК Контрагент%%% ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоКт1) КАК КонтрагентПредставление%%% ХозрасчетныйДвиженияССубконто.СубконтоДт3 КАК НомГруппа%%% ПРЕДСТАВЛЕНИЕ(ХозрасчетныйДвиженияССубконто.СубконтоДт3) КАК НомГруппаПредставление%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL  ТОГДА -ХозрасчетныйДвиженияССубконто.Сумма ИНАЧЕ -ХозрасчетныйДвиженияССубконто.ВалютнаяСуммаКт КОНЕЦ КАК Сумма%%% ВЫБОР КОГДА ХозрасчетныйДвиженияССубконто.ВалютаКт ЕСТЬ NULL ТОГДА Константы.ВалютаУправленческогоУчета ИНАЧЕ ХозрасчетныйДвиженияССубконто.ВалютаКт КОНЕЦ КАК Валюта%%% -ХозрасчетныйДвиженияССубконто.Сумма КАК Сумма1%%% ХозрасчетныйДвиженияССубконто.Регистратор КАК Регистратор%%% ХозрасчетныйДвиженияССубконто.Содержание КАК Содержание ИЗ РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто(ДАТАВРЕМЯ(2015, 10, 01), ДАТАВРЕМЯ(2015, 10, 31), СчетДт.Код = !!!91!!! ИЛИ СчетДт.Код = !!!92!!! ИЛИ СчетДт.Код = !!!93!!!, , ) КАК ХозрасчетныйДвиженияССубконто, Константы КАК Константы

, но результат такой же



0



  • 1h 563 ошибка будерус logano
  • 1f4a08 ошибка бмв f10
  • 1f2802 ошибка bmw 7
  • 1f0530 bmw ошибка f30
  • 1f0515 ошибка бмв f20