Microclimate.su

IT Новости
0 просмотров
Рейтинг статьи
1 звезда2 звезды3 звезды4 звезды5 звезд
Загрузка...

Ошибка запроса error

Что такое 500 Internal Server Error

Внутренняя ошибка сервера 500 появляется по многим причинам. Чтобы их выявить, нужно поочередно проверить все параметры отправки запроса. Для решения проблемы, в лучшем случае, достаточно переписать директиву в .htaccess, в худшем — придется заново создавать сайт.

Что такое 500 — ошибка Internal Server Error

500 — код ошибки, который выдает протокол HTTP в ответ на запрос клиента. Подобные сбои возникают чаще при нарушении работы сервера либо в случае отказа одного из компонентов загрузки. Технически все работает правильно, но что-то мешает запросам обрабатываться правильно, в результате чего выводится характерное сообщение на экран.

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

Возможные причины Internal Server Error

  1. Ошибки в логах сервера. Чтобы их выявить, необходимо провести техническую проверку сайта. В панели хостинга нужно найти файлы access.log (логи сервера) и error.log (ошибки логов).

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

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

Рекомендуется устанавливать такие параметры доступа: 755 — для папок, 600 — для скриптов и 640 — для остальных файлов. В целях безопасности лучше, чтобы правами доступа к файлам и папкам обладал один человек. Автоматически этот параметр может измениться при восстановлении сайта либо загрузке новых файлов.

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

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

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

  1. Неправильно составленный файл .htaccess. Нарушение правил иерархии файла, внесение лишних директив приводит к ошибке 500. Найдите .htaccess в корневой папке сайта через файловый менеджер или панель хостинга.

Измените название файла, добавив в него один дополнительный символ. В итоге получится, например, .htaccess5. После этого перезагрузите страницу в браузере. Если сайт заработал с отключенным .htaccess, причина сбоя кроется в нем. Попробуйте отредактировать этот файл. Для внесения правок следует нажать на него, либо вызвать контекстное меню правой кнопкой мыши, затем выбрать соответствующий пункт — редактирование.

После того, как он откроется, появится список параметров и директив. Обратите внимание, есть ли в этом списке директива Options. Поставьте перед ней знак #. В этом случае сервер будет воспринимать данную директиву, как комментирование, а не команду. Также можно заменить строку Options All -Indexes на Options -Indexes либо исправить строку Options +FollowSymLinks на Options +SymLinksIfOwnerMatch. Если эти шаги не помогут, попробуйте удалить параметры +ExecCGI, php_value, AddHandler, php_flag и директиву -MultiViews.

Если внесенные правки не помогают, удалите существующий файл .htaccess и создайте новый со стандартным синтаксисом. Вариант для WordPress:

Для сайтов на Joomla можно скачать код .htaccess в соответствии с выбранной версией данной CMS.

  1. Нехватка памяти для загрузки скриптов. Сервер обладает лимитированной памятью. К тому же количество мегабайт может быть ограничено со стороны хостинг-провайдера из-за выбранного бюджетного тарифа. Ошибка сервера 500 также может возникать из-за ограниченного времени для загрузки скриптов. Создается большое количество запросов к серверу, который не способен их обработать. Через некоторое время связь обрывается и появляется надпись Internal Server Error.

Проверить работу скриптов можно через соответствующие плагины. Например, Query Monitor в WordPress, JsCssManipulate в Joomla, либо через установку профайлера XHprof. Если это не помогло, попробуйте увеличить память через РНР. Для этого добавьте в конец файла .htaccess часть кода:

Устанавливать объем памяти РНР можно и через панель хостинга.

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

В этом же разделе можно изменить тип отображения ошибок на сайте. Установите флажок возле соответствующих пунктов.

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

Другие варианты исправления ошибки 500 в WordPress

  1. Восстановление резервной копии. Этот вариант подходит при наличии созданной копии до поломки сайта. В панели управления хостингом доступны функции импорта/экспорта резервных копий сайта.

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

  1. Отладка системы. Для активации отладки нужно внести изменения в файл wp-config.php через файловый менеджер либо панель хостинга. Найдите в файле строку

и замените ее на:

Обновите сайт, после чего найдите каталог wp-content в панели хостинга или файловом менеджере и откройте редактирование файла debug.log. Откроется значение, в котором будет указан источник ошибки.

  1. Перезапись файлов WordPress. В этом случае информация о сайте сохраняется, а стандартные файлы WordPress перезаписываются. Для этого скачайте последнюю версию системы на компьютер и распакуйте ее. Создайте резервную копию сайта, удалите файлы wp-content и wp-config-sample.php из скачанной новой версии. Это делается для предотвращения потери информации о существующем сайте. Далее в файловом менеджере выделите старые файлы и замените их на новые из скачанной версии WordPress.

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

Запомнить

Ошибка сервера 500 возникает по одной или нескольким причинам:

  • проблемы с логами сервера;
  • нарушение структуры файла .htaccess;
  • сбои в корневой файловой системе;
  • нехватка объема памяти для загрузки скриптов;
  • долгая загрузка файлов и скриптов;
  • конфликты после обновления CMS, установки плагинов и тем;
  • ошибки в правах доступа к файлам.

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

Ошибка при выполнении запроса к БД

07.02.2016, 11:52

Ошибка при выполнении запроса
Всем привет! Использую php версии 5.6 Есть файл addBook.php

Ошибка при выполнении запроса
ПРи выполнении пхп запроса $sql1 = » INSERT INTO `d4msz_content` (`title`, `introtext`.

07.02.2016, 12:382

Если используете mysqli, то почему mysql_error?

Читать еще:  Ошибка 498 на андроиде

Да, если принимаете много данных, и названия полей формы соответствуют названиям полей в БД, проще использовать циклы, чем писать кучу раз одни и те же названия, да и ошибки в них часто возникают:

А если понадобится проверять переменные на наличие, плюс экранировать для защиты от SQL-инъекций. запрос точно превратится в кашу. С циклами проще:

07.02.2016, 13:13 [ТС]3

Попробовал поменял, выдает ошибку:

Warning: mysqli_error() expects exactly 1 parameter, 0 given in C:xampphtdocsreport.php on line 32
Ошибка при выполнении запроса к базе данных:

line 32 — or die («Ошибка при выполнении запроса к базе данных:» . mysqli_error());

До циклов пока не дошел спасибо за совет, в дальнейшем изучу

Добавлено через 21 минуту
Вставил: ($dbc)

07.02.2016, 13:57407.02.2016, 14:47 [ТС]507.02.2016, 16:116

Покажусь навязчивым, но лучше сразу изучайте PDO и обертки к нему. Потом еще спасибо скажете.

Добавлено через 5 минут

07.02.2016, 19:58722.02.2017, 03:08822.02.2017, 11:05922.02.2017, 15:2910

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

Добавлено через 50 минут
Не помогло переименование, всё равно выдает ошибку «Ошибка при выполнении запроса к базе данных».
Вот код:

22.02.2017, 15:441122.02.2017, 15:5412

Где кавычки и почему только 2 параметра?

Как исправите, читайте про mysqli_error.

22.02.2017, 21:1913

Спасибо за ответ, я не пропала, я просто думаю — какое у меня имя пользователя? какой пароль? ((( Как выясню — отпишусь..

Добавлено через 4 часа 49 минут
Вот на такой запрос уже дает другую ошибку: No database selected.

22.02.2017, 21:211422.02.2017, 21:221522.02.2017, 21:2516

Ок, сейчас попробую.

Добавлено через 2 минуты
Спасибо, всё получилось!

11.03.2017, 12:1217

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

Ошибка запроса к базе данных. MySQL пишет: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near » at line 1

Где ошибка, плиз? База данных работоспособная, в phpMyAdmin записи удаляюся, добавляются, редактируются.

Предложение от 8host.com

Коды ошибок HTTP: расшифровка и устранение

При обращении к веб-серверу или приложению каждый поступивший HTTP-запрос получает в качестве ответа код состояния HTTP (англ. HTTP status code). Коды состояния HTTP – это трехзначные коды, сгруппированные в пять различных классов. Класс кода состояния можно определить по первой цифре:

  • 1хх – информационные коды;
  • 2хх – успех;
  • 3хх – перенаправление;
  • 4хх – ошибка клиента;
  • 5хх – ошибка сервера.

Это руководство фокусируется на выявлении и устранении наиболее часто встречающихся кодов ошибок HTTP (то есть кодов состояния 4xx и 5xx) с точки зрения системного администратора. В некоторых ситуациях веб-сервер отвечает на запрос определенным кодом ошибки; рассмотрим общие возможные причины и решения.

Краткий обзор ошибок клиента и сервера

Ошибки клиента (коды состояния HTTP 400-499) возникают из-за HTTP-запросов, отправленных клиентом (веб-браузером или другим клиентом HTTP). Хотя данные типы ошибок связаны непосредственно с клиентом, системному администратору полезно знать, с какими кодами ошибок может столкнуться пользователь, чтобы определить, можно ли решить эту проблему в конфигурациях сервера.

Ошибки сервера (коды состояния HTTP 500-599) возникают тогда, когда веб-сервер не в состоянии обработать запрос из-за какой-либо ошибки или сбоя.

Общие советы по устранению ошибок HTTP

  • При использовании веб-браузера для тестирования веб-сервера не забудьте обновить браузер после внесения изменений в настройки сервера.
  • Проверяйте логи сервера, чтобы получить подробные сведения о том, как сервер обрабатывает запросы. Например, веб-серверы Apache и Nginx создают два файла по имени access.log и error.log, в которых можно найти соответствующую информацию.
  • Запомните: определения кодов состояния HTTP являются частью стандарта, который реализуется обслуживающим запросы приложением. Это означает, что фактический код состояния, который возвращается в результате, зависит от того, как программное обеспечение сервера обрабатывает конкретную ошибку.

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

Ошибка 400 Bad Request

Код статуса 400, или ошибка Bad Request («неверный запрос») означает, что синтаксис запроса HTTP, отправленного на сервер, неверен.

Как правило, причины возникновения ошибки 400 Bad Request таковы:

  • Куки пользователя, связанные с сайтом, повреждены. Чтобы решить эту проблему,, попробуйте очистить кэш браузера и файлы cookie.
  • Искаженный запрос из-за неисправного браузера.
  • Искаженный запрос из-за ошибки пользователя при формировании HTTP-запроса вручную (например, неправильное использование curl).

Ошибка 401 Unauthorized

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

Например, ошибка 401 Unauthorized может возникнуть, если пользователь пытается получить доступ к ресурсу, который защищен HTTP-авторизацией (как в этом руководстве по Nginx). В подобной ситуации ошибка 401 будет появляться снова и снова до тех пор, пока пользователь не предоставит корректный логин и пароль (который внесен в файл .htpasswd).

Ошибка 403 Forbidden

Код состояния 403, или ошибка Forbidden («запрещено») значит, что запрос пользователя был отправлен верно, но сервер отказывается обслуживать его в связи с отсутствием разрешения на доступ к запрашиваемому ресурсу. В этом разделе описаны наиболее распространенные причины возникновения ошибки 403.

Права на файл

Как правило, ошибка 403 случается, если пользователь, который запускает процесс веб-сервера, не имеет прав на чтение запрашиваемого файла.

Чтобы привести пример устранения ошибки 403, предположим, что:

  • пользователь пытается получить доступ к индексному файлу (http://example.com/index.html);
  • рабочий процесс веб-сервера принадлежит пользователю www-data;
  • индексный файл на сервере находится в /usr/share/nginx/html/index.html.

Итак, если пользователь получает ошибку 403 Forbidden, убедитесь, что пользователь www-data имеет права на чтение файла. Как правило, в подобной ситуации нужно просто изменить права на файл. Это можно сделать несколькими способами, но в данном случае подойдет вот эта команда:

sudo chmod o=r /usr/share/nginx/html/index.html

Файл .htaccess

Еще одна потенциальная причина возникновения ошибки 403 (часто это делается намеренно) — использование файла .htaccess. При помощи файла .htaccess можно запретить конкретным IP-адресам (или диапазонам адресов) доступ к определенным ресурсам.

Если пользователи неожиданно получают ошибку 403 Forbidden, убедитесь, что она не была вызвана настройками файла .htaccess.

Несуществующий индексный файл

Если пользователь пытается получить доступ к каталогу, который не имеет стандартного индексного файла, а листинг каталога (directory listing) отключен, веб-сервер будет возвращать ошибку 403 Forbidden. Такое случится, если, например, пользователь попытается получить доступ к каталогу http://example.com/emptydir/, а в каталоге emptydir на сервере нет индексного файла. Листинг каталога можно включить в конфигурациях сервера.

Ошибка 404 Not Found

Код статуса 404, или ошибка Not Found («не найдено») значит, что пользователь может взаимодействовать с сервером, но требуемый файл или ресурс отсутствует.

Читать еще:  Что за ошибка 498

Ошибки 404 могут возникнуть в самых различных ситуациях. Ниже приведен список советов, которые помогут устранить проблему в случае, если пользователь неожиданно получил 404 Not Found:

  • Проверьте ссылку, которая направляет пользователя на сервер, на наличие ошибок или опечаток.
  • Возможно, пользователь ввел неверный URL.
  • Может быть, нужного файла не существует в указанном месте на сервере; убедитесь, что запрашиваемый ресурс не был перемещен или удален с сервера.
  • Проверьте, правильно ли указано местонахождение корневого каталога (document root) в конфигурации сервера.
  • Возможно, пользователь, которому принадлежит рабочий процесс веб-сервера, не имеет соответствующих прав, чтобы открыть каталог, в котором находится запрашиваемый файл. Для доступа к каталогу нужны права на чтение и выполнение.
  • Если пользователь переходит к ресурсу по символической ссылке, убедитесь, что веб-сервер настроен для поддержки символических ссылок.

Ошибка 500 Internal Server Error

Код состояния 500, или ошибка Internal Server Error («внутренняя ошибка сервера») означает, что сервер не может обработать запрос по неизвестной причине. Иногда этот код появляется в ситуациях, когда более подходящими являются другие сообщения об ошибках 5xx.

Как правило, причиной данной ошибки является неправильная настройка сервера (например, искаженный файл .htaccess) или нехватка некоторых пакетов (к примеру, запуск файла PHP без предварительно установленного PHP).

Ошибка 502 Bad Gateway

Код состояния 502, или ошибка Bad Gateway («ошибочный шлюз») значит, что запрашиваемый сервер является шлюзом или прокси-сервером, и он не получает валидных ответов от серверов бэкэнда, которые на самом деле выполнили запрос.

Если речь идет об обратном прокси-сервере (например, о балансировщике нагрузки), убедитесь, что:

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

Ошибка 503 Service Unavailable

Код состояния 503, или ошибка Service Unavailable («сервис недоступен») означает, что сервер перегружен или находится на обслуживании; такой сервис должен стать доступным в течение некоторого времени.

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

Ошибка 504 Gateway Timeout

Код состояния 504, или ошибка Gateway Timeout («шлюз не отвечает») значит, что данный сервер является шлюзом или прокси-сервером, и он не получает ответа от бэкэнда в пределах допустимого периода времени.

Как правило, это происходит по следующим причинам:

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

Заключение

Теперь вы знакомы с основными кодами ошибок HTTP и знаете некоторые пути решения этих проблем.

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

Ошибка 400 Bad Request: что это означает и как ее исправить

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

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

На стороне сервера или на стороне клиента?

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

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

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

Начните с тщательного резервного копирования приложения

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

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

Диагностика ошибки 400 Bad Request

Ошибка 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 ( попробуйте позже ) лучше начать с исправления на стороне клиента. Вот несколько советов, что следует попробовать в браузере или на устройстве, которые выдают ошибку.

Проверьте запрошенный URL

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

Читать еще:  Код ошибки 0 34

Важно проверять 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 , которые ожидает получить приложение или сервер. В подобных случаях нужно проанализировать заголовки HTTP , которые отправляются на сторону сервера.

Просмотрите логи

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

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

Отладьте код приложения или скриптов

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

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

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

Данная публикация представляет собой перевод статьи « 400 Bad Request Error What It Is and How to Fix It » , подготовленной дружной командой проекта Интернет-технологии.ру

Ссылка на основную публикацию
Adblock
detector