Ajax отправка файла 500 ошибка
У меня есть Ajax, который работает на реальном сайте, теперь он перестает работать. Ajax должен возвращать страницу, но возвращает ошибку 500 (внутренняя ошибка сервера) .
Еще одна странная вещь - это нормально работать на месте, но не жить. Также работает все другие Ajax на сайте.
Кто-нибудь имеет туманность, что это может быть? Кстати, это все jQuery с CakePHP.
Изменить :
Бит Apache говорит: «Преждевременный конец заголовков скриптов: php-script, referer . »
Изменить 2 :
Все это произошло, когда я переключил сервер на SSL. Он говорит выше ошибки, а затем «Порт 80».
Ошибки сегментации PHP могут быть трудными для устранения неполадок, и их никогда не должно было случиться; PHP никогда не должен терпеть крах. Причина, по которой это происходит, может быть вызвана рядом вещей. Возможно, это простое решение.
Первое, что я хотел бы сделать, это полностью удалить PHP и установить последнюю стабильную версию. Если вы используете PHP 5.3 и Windows, вам следует использовать только VC6 libmySQL.dllaries (пакет VC6 x86 Thread Safe); пакет VC9 вызовет сбой PHP при использовании Apache. Повторная установка может устранить вашу проблему, поскольку DLL-расширения DLL / SO более старых версий PHP могут все еще существовать в вашем каталоге расширений на реальном сервере.
Если оба эти предложения не решают проблему, пожалуйста, обновите свой вопрос с ответами на следующее:
- Используете ли вы веб-узел или ИТ-команда компании управляет сервером для вашего использования?
- Если вы используете веб-хостинг, вы арендуете выделенный сервер?
- В какой операционной системе вы работаете?
- Какую версию PHP вы используете?
- Какие расширения PHP загружаются?
- Вы загружаете расширение Zend?
- Вы когда-нибудь использовали dl ?
Проверьте свои apache и php error logs ! он будет там
Это, как правило, необходимо только при вызове внешних программ из вашего сценария, которые отправляют вывод на stdout, или если будет длительная задержка между временем отправки заголовков и фактическим выпуском контента. Чтобы максимизировать производительность, вы должны отключить сброс буфера (с помощью $ | = 0 или эквивалент) после операторов, отправляющих заголовки, как показано выше.
Если ваш скрипт не написан на Perl, выполните эквивалентную вещь для любого языка, который вы используете (например, для C, вызовите fflush () после написания заголовков).
Стоит проверить права доступа к каталогу.
Вы можете использовать Fidler для проверки того, что сервер вернул в течение этого $ .post. Он будет содержать веб-страницу, которая была бы возвращена, если бы вы запускали тот же самый метод непосредственно в своем браузере.
Эта ошибка немного проблематична, потому что это может быть вызвано множеством вещей.
Что делает ваша страница . Вот некоторые предложения.
Если ваша страница похожа на страницу автозаполнения, поэтому вы передаете немного информации и получите отфильтрованный список результатов . Возможно, ваш сценарий AJAX не передает элемент данных, и ваша страница пытается вернуть все. На самом деле это громоздкие скрипты PHP (т.е. интенсивные / рекурсивные операции).
Обычным советом для борьбы с этой конкретной ошибкой является отбрасывание на стабильную страницу, а затем начать добавлять материал обратно - так что, возможно, укажите ваш скрипт AJAX на странице, которая имеет это .
Затем постепенно добавляйте блоки своего кода, пока не столкнетесь с проблемой. Моя предлагаемая версия 2 этой страницы будет .
В противном случае, пожалуйста, поставьте следующее .
1) Описание того, что делает ваша страница PHP, или, может быть, пример кода. 2) Код JavaScript, вызывающий страницу PHP.
Я пытаюсь выполнить эту запись AJAX, но по какой-то причине я получаю ошибку сервера 500. Я вижу, что это хит точки останова в контроллере. Таким образом, проблема, кажется, на обратном вызове. Кто-нибудь?
Это строка, которая должна быть возвращена:
Я подозреваю, что серверный метод бросает исключение после прохождения точки останова. Используйте Firefox/Firebug или инструменты разработчика IE8, чтобы посмотреть на фактический ответ, который вы получаете с сервера. Если возникло исключение, вы получите YSOD html, который поможет вам понять, где искать.
Еще одно: ваше свойство данных должно быть <> not "<>", первый - пустой объект, а последний - строка, которая является недопустимой как параметр запроса. Еще лучше, просто оставьте это, если вы не передаете какие-либо данные.
если кто-то использует фреймворк codeigniter, проблема может быть вызвана включенной конфигурацией защиты csrf.
У меня была сама проблема, хотя я не мог найти причину этого в моем случае при изменении от POST до GET ошибка 500 проблемы исчезла!
Это простой запрос Ajax Request для получения данных через запрос Ajax
"Сервер столкнулся с неожиданным условием, которое помешало ему выполнить запрос".
Вам нужно отладить ваш сервер.
Следующая отладка на стороне клиента позволила мне определить ошибку сервера
В обратном вызове $.ajax отобразите подробные сведения об ошибке на консоли
Это, по крайней мере, позволило мне просмотреть начальную ошибку сервера
"Запрос JSON был слишком большим для сериализации"
Это было разрешено в клиенте web.config
Однако запрос еще не удался. Но на этот раз с другой ошибкой, которую я теперь мог отлаживать на стороне сервера
"Request Entity слишком большой"
Это было разрешено путем добавления следующего к сервису web.config
Я предлагаю вам приложить отладчик к процессу веб-сервера (при условии, что у вас есть доступ).
Одна странная вещь: вы делаете запрос POST на сервер, но вы не передаете никаких данных (все в строке запроса). Возможно, это должен быть запрос GET?
Вы также должны проверить правильность URL-адреса.
Но я могу сказать, что "ошибка внутреннего сервера 500" - это ошибка с сервером, а не с клиентом, вы получили ошибку на стороне сервера script. Прокомментируйте закрытие кода закрытием и попробуйте запустить его снова, вы скоро узнаете, что вам не хватает персонажа.
Вы также можете получить эту ошибку в VB, если вызываемая вами функция начинается с Public Shared Function, а не Public Function в веб-сервисе. (Как может случиться, если вы переместите или скопируйте функцию из класса). Еще одна вещь, на которую нужно следить.
Можете ли вы опубликовать подпись своего метода, который должен принять этот пост?
Тогда мой javascript errorFunc выглядит так:
так что проверьте все это и опубликуйте подпись своего контроллера в случае, если часть проблемы
Странно то, что я могу перемещаться и публиковать на странице, которую вызывает Ajax, поэтому страница не работает только через вызов Ajax ($ .post).
Еще одна странная вещь, это работает нормально локально, но не жить. Также все остальные Ajax на сайте работают.
У кого-нибудь есть сомнения, что это может быть? Кстати это все jQuery с CakePHP.
Изменить :
Журналы ошибок apache говорят: «Преждевременный конец заголовков скриптов: php-script, referer . »
Изменить 2 :
Все произошло, когда я переключил сервер на SSL. Это говорит об ошибке выше, а затем "Порт 80".
Первое, что я хотел бы сделать, это полностью удалить PHP и установить последнюю стабильную версию. Если вы используете PHP 5.3 и Windows, то вы должны использовать только двоичные файлы VC6 (пакет «VC6 x86 Thread Safe»); пакет VC9 приведет к сбою PHP при использовании Apache. Переустановка может решить вашу проблему, потому что библиотеки DLL / SO расширений более ранних версий PHP могут все еще существовать в каталоге расширений на работающем сервере.
Если оба эти предложения не решают проблему, обновите свой вопрос, ответив на следующие вопросы:
- Вы используете веб-хостинг или IT-команда компании управляет сервером для вашего использования?
- Если вы используете веб-хостинг, вы арендуете выделенный сервер?
- Какую операционную систему вы используете?
- Какую версию PHP вы используете?
- Какие расширения PHP загружаются?
- Вы загружаете расширение Zend?
- Вы когда-нибудь использовали dl ?
У меня также была эта проблема, в моем случае решение было заменить файл php.ini на чистый.
Вы должны проверить php error.log, в моем случае я установил тип кэша с помощью redis, однако он работает неправильно.
Я хотел бы добавить свои 2 цента, но это происходит немного в другом направлении, и у вас могут быть или не быть прямые ресурсы для устранения неполадок, но об этом стоит подумать.
Вообще говоря, это ошибка PHP, и мы можем исключить проблемы на стороне клиента. Кроме того, в моей повседневной работе (устранение неполадок в сети), если что-то работает, а затем останавливается, я сразу же думаю, «что изменилось». Если вы ничего не добавили в сценарий, и у пользователя нет возможности повлиять на сценарий во время выполнения, тогда я бы сразу начал думать: «О-о, что с инфраструктурой». Это особенно верно, если что-то работает локально, но не через Интернет.
Проверяли ли вы наличие плохой памяти на сервере или плохих сетевых карт (если плохие сетевые карты, это объясняет, почему работает один интерфейс, а не другой). У вас есть доступ к этому или он размещен (может ли ваш хост проверить)?
Затем я бы начал думать, что с серверной памятью все в порядке, и, скорее всего, она не связана с неисправной сетевой картой, в противном случае произойдет сбой в некоторых местах. Тем не менее, может быть сеть, хотя. Существует ли устройство безопасности, которое может манипулировать пакетами в любом месте микса (NIDS / HIDS, WAF, прокси-сервер и т. Д.). Видите ли вы какие-либо проблемы с пакетами в сети (дубликаты, вышли из строя, не фрагментированы и т. Д.).
Я буду честен, если бы кто-то позвонил мне и описал ваши проблемы, первое, что я хотел бы сказать, это «проверить журналы IPS», примерно 85% - это проблема. Ложные срабатывания могут сделать это, и все, что нужно, это одно автоматическое обновление на брандмауэре .
Надеюсь, это поможет.
Возможно, производственный сайт нарушает ту же политику происхождения.
URL в браузере до третьей косой черты должен точно соответствовать URL в вашем AJAX POST, иначе ограничения безопасности браузера для Javascript откажут в ответе. Сервер может действительно увидеть запрос и ответить правильно, но браузер передает пустую строку обратно вызову AJAX.
Эта ошибка немного проблематична, потому что она может быть вызвана многими причинами.
Что делает ваша страница . Вот несколько предложений.
Если ваша страница похожа на страницу автозаполнения, поэтому вы передаете немного информации и получаете отфильтрованный список результатов обратно . Возможно, ваш AJAX-скрипт не передает элемент данных, и ваша страница пытается вернуть все. Действительно громоздкие PHP-скрипты (т.е. интенсивные / рекурсивные операции) могут вызвать эту ошибку.
Обычный совет для решения этой конкретной ошибки - вернуться к стабильной странице, а затем начать добавлять материал обратно - поэтому, возможно, укажите свой сценарий AJAX на страницу, которая имеет это .
Затем постепенно добавляйте блоки своего кода, пока не столкнетесь с проблемой. Моя предложенная версия 2 этой страницы будет .
Если все вышеперечисленное не выполнено, укажите следующее .
1) Описание того, что делает ваша PHP-страница, или, возможно, пример кода. 2) Код JavaScript, который вызывает страницу PHP.
Вы можете использовать Fidler, чтобы проверить, что сервер возвратил за этот $ .post. Он будет содержать веб-страницу, которая была бы возвращена, если бы вы запустили этот же метод прямо в браузере.
Стоит проверить каталог разрешений.
Проверьте свой apache и php error logs ! это будет там
Как правило, это необходимо только в том случае, если вы вызываете из своего скрипта внешние программы, которые отправляют выходные данные в stdout, или если между временем отправки заголовков и фактическим содержимым начнется длительная задержка. Чтобы максимизировать производительность, вы должны выключить очистку буфера (с $ | = 0 или эквивалентной) после операторов, которые отправляют заголовки, как показано выше.
Если ваш скрипт написан не на Perl, сделайте то же самое для любого языка, который вы используете (например, для C, вызовите fflush () после написания заголовков).
Разбираемся, что означает ошибка 500, из-за чего она может возникнуть и что делать, чтобы убрать её с сайта.
Что внутри
Что такое ошибка 500
Сервер отправляет один из таких кодов каждый раз, когда в браузере открывают новую страницу или переходят по ссылке. Даже когда никакой ошибки не было и страница нормально загрузилась.
Как может выглядеть ошибка 500
Дизайн страницы с 500 ошибкой будет отличаться в зависимости от разных факторов: вашего браузера, веб-сервера, панели управления хостингом, операционной системы, а также движка или фреймворка, на котором работает сайт.
Например, вот так выглядят стандартные страницы 500 ошибки четырёх популярных веб-серверов: Apache, Nginx, LiteSpeed и IIS 7.
Когда что-то не так с параметрами PHP или правами на файлы и папки, в Google Chrome 500 ошибка будет оформлена в фирменном стиле браузера, а в Firefox будет пустая страница — «белый экран смерти».
Когда на сайте с WordPress есть проблема со скриптом — написан с ошибкой или в нём пропущен символ — тоже возникнет ошибка 500:
Также страницу с 500 ошибкой иногда оформляют в общем дизайне сайта. Вот так, например, выглядит страница с такой ошибкой на сайте YouTube:
Это не все варианты, а только самые популярные. В зависимости от того, какое ПО вы используете, оформление страницы с ошибкой может быть и другим.
Текст на странице тоже может отличаться. Вот некоторые варианты, с которыми вы можете столкнуться:
Почему возникает ошибка 500
Проще всего посмотреть в логи сервера, чтобы найти причину возникновения 500 ошибки. Но вообще, вот несколько распространенных ситуаций, в которых она возникает:
- ошибка в скрипте PHP;
- проблемы с базой данных;
- неправильные параметры PHP;
- неправильные права доступа к папкам и файлам;
- сайт вступает в конфликт с шаблоном или расширением;
- отсутствует или повреждён системный файл движка сайта;
- ошибка в глобальном конфигурационном файле веб-сервера;
- ошибка в дополнительном конфигурационном файле веб-сервера .htaccess;
- в одном из файлов есть ссылка на другой файл, но сам файл отсутствует;
- скрипт не выполняется из-за слишком низких значений max_execution_time и memory_limit.
Как 500 ошибка влияет на SEO
Когда поисковый робот заходит на страницу и видит 500 ошибку, он пробует зайти на страницу ещё раз в пределах суток, рассчитывая на то, что владелец сайта решит проблему. Но если при повторном посещении снова будет код ответа сервера 500, бот уже может исключить страницу из индекса.
Проверить, выпала ли страница из индекса, можно в Google Search Console. Для этого войдите в консоль, введите в строке поиска URL страницы и нажмите Enter. Сервис проверит страницу и покажет её статус. Если страницы уже нет в индексе, нажмите «Запросить индексирование», чтобы повторно её туда добавить.
Также Search Console поможет вам своевременно обнаруживать ошибки. Для этого просто периодически проверяйте раздел «Покрытие» на главной странице панели в меню слева. В него будут записываться все ошибки на сайте.
Если вы столкнулись с ошибкой как посетитель, ваша единственная опция описана в первом совете. Для остальных советов понадобится доступ на хостинг.
Советы в этом разделе описывают не все ситуации, из-за которых может возникнуть 500 ошибка, а только наиболее популярные. Если ничего из перечисленного выше не поможет, в конце статьи есть рекомендация, что делать.
1. Очистите кэш и обновите страницу
Бывает, 500 ошибка возникает в моменте и пропадает при повторной загрузке страницы. При этом иногда она кэшируется, поэтому кэш на всякий случай стоит очистить. Вот как сделать это в популярных браузерах:
У нас на YouTube-канале также есть видеоинструкция: Как очистить кэш.
2. Проверьте логи
Так вы сразу увидите причину ошибки, вместо того чтобы перебирать все возможные варианты. Если вы не сильно разбираетесь, попробуйте сначала советы ниже. А уже если ничего не сработает, придётся возвращаться к этому варианту.
В зависимости от того, какой веб-сервер используется у вас на хостинге, по умолчанию логи будут храниться по таким путям:
Логи могут храниться и в других местах. Например, панели управления хостингом часто меняют стандартный путь их расположения:
- /usr/local/apps/apache/logs/vashdomen.err для бесплатной панели Webuzo у нас на хостинге;
- /usr/local/apache/logs/error_log — Apache с установленной cPanel & WHM.
Важный нюанс — доступ к общим логам будет только на VPS-хостинге или выделенном сервере. На виртуальном хостинге будет свой файл error_log. По умолчанию он создаётся в той же папке, где лежит скрипт, выполнение которого привело к 500 ошибке. Но разные CMS могут переопределять путь к этому файлу в другие папки.
Плюс в этот файл попадают только ошибки PHP. Ошибки веб-сервера попадут в основные логи, к которым не будет доступа. Так что, если у вас виртуальный хостинг и в логах с ошибками PHP пусто, свяжитесь с поддержкой провайдера и попросите их посмотреть основные логи. Пусть пришлют последние строки оттуда.
Вы также можете включить опцию display_errors, чтобы причина ошибки из логов отображалась на сайте. В панели управления cPanel для этого нужно найти на главной странице панели раздел «Программное обеспечение» и открыть приложение «Выбор версии PHP».
Дальше перейдите на вкладку «Настройки» и поставьте галочку в строке «display_errors». Изменения сохранятся автоматически.
На VPS или выделенном сервере добавьте такую директиву в основной файл php.ini:
В этом случае 500 ошибка возникла из-за того что серверу обязательно нужно открыть файл version.php (слово «require» в самом начале), как указано на 33 строке в файле wp-settings.php, но прав для открытия этого файла нет (слова «Permission denied»).
3. Проверьте глобальные конфигурационные файлы
Если у вас виртуальный хостинг, беспокоиться не о чем. За настройку этих файлов отвечает хостинг-провайдер и вероятность возникновения ошибки из-за проблемы с этим файлом стремится к нулю.
Если у вас VPS или выделенный сервер, вы сами отвечаете за настройку этих файлов. И в этом случае 500 ошибку может вызвать случайная опечатка или конфликтующие директивы.
У веб-сервера Apache конфигурационные файлы хранятся в таких местах:
У веб-сервера Nginx конфигурационные файлы хранятся в таких местах:
- Основной конфигурационный файл nginx.conf в каталоге /etc/nginx/.
- Дополнительные конфигурационные файлы, в которых размещены виртуальные хосты, в каталогах /etc/nginx/conf.d/, /etc/nginx/sites-available/ или /etc/nginx/sites-enabled/.
Если вы управляете сервером при помощи какой-то панели управления, конфигурационные файлы могут храниться в других папках. Например, для Webuzo это /usr/local/apps/apache, а для Plesk — /home/user/conf/.
4. Проверьте вспомогательный конфигурационный файл .htaccess
Этот файл будет в корневой папке домена на любом хостинге с веб-сервером Apache. Даже если вы никогда не редактировали его, в файле всё равно может быть ошибка. Например, такое бывает с сайтами на WordPress: при установке плагинов они сами добавляют нужные директивы в файл, из-за чего иногда возникают конфликты с предыдущими директивами и возникает 500 ошибка.
Чтобы проверить, действительно ли дело в .htaccess, переименуйте его на хостинге и снова зайдите на сайт. С другим названием файл не будет работать. Если ошибка пропадёт, проблема именно в файле. Остаётся только найти директиву, которая вызывает ошибку. Для этого добавьте знак решетки в начале каждой строки директивы:
Читайте подробнее на эту тему: Как работать с .htaccess.
5. Проверьте права доступа к папкам и файлам
Ошибка 500 Internal Server Error часто возникает, потому что у веб-сервера нет доступа к какой-то папке или файлу, из-за чего он не может выполнить скрипт. Дело может быть в том, что у файла или папки в принципе нерабочие права, а может в том, что файлом или папкой владеет один пользователь, а веб-сервер выполняет процессы от имени другого; у владельца права есть, а у веб-сервера нет.
Изменить владельца можно в командной строке при помощи команды chown:
Изменить права можно либо при помощи FTP-клиента вроде FileZilla, если вы таким пользуетесь, либо при помощи менеджера файлов в панели управления хостингом. Вот как сделать это в cPanel.
На главной странице панели найдите блок «Файлы» и перейдите в раздел «Менеджер файлов».
Выделите нужный файл или папку и нажмите в верхней панели кнопку «Права». Вот стандартные значения, с которыми всё должно работать:
Если привыкли работать с файлами в командной строке, вот команда, которая поможет изменить права:
6. Проверьте базу данных
Ошибка Internal Server Error ещё возникает, когда сервер не может подключиться к базе данных. Текст ошибки в этом случае будет «Error establishing a database connection», но в логах будет код ошибки 500.
Чаще всего сервер не может подключиться к базе данных из-за того, что в файле с деталями базы указан неправильный логин или пароль. Такое может произойти, если вы или ваш программист поменяли детали, но случайно забыли обновить их в файле. Расположен этот файл обычно в корневой папке сайта и в его названии есть слово config. Например, для сайтов на WordPress это wp-config.php, а для сайтов на OpenCart — config.php.
Также дело может быть в том, что MySQL-сервер перегружен из-за большого количества посетителей. Такое часто бывает на виртуальном хостинге, где для каждого пользователя ограничено количество одновременных подключений к базе.
Запросов к базе данных может стать больше по мере естественного роста трафика на сайт. Это обычно значит, что нужен более мощный хостинг. Либо запросы могут быть вредоносными и тогда нужно просто от них отбиться. Проверить нагрузку можно при помощи команд SHOW GLOBAL STATUS, VMSTAT или TOP. Если не разбираетесь, обратитесь за помощью к разработчику сайта или поддержке вашего хостинг-провайдера.
Ещё ошибку Error establishing a database connection может вызвать повреждение в базе данных. По мере того как вы наполняете свой сайт контентом, устанавливаете темы и плагины, оптимизируете при помощи разных инструментов, что-то важное может случайно удалиться, из-за чего база и перестанет работать. В этом случае решением будет восстановить резервную копию, если она есть.
7. Проверьте использование ресурсов на сервере
Любое действие на сайте запускает на сервере процесс. Если их будет слишком много и все ресурсы окажутся заняты, начнёт образовываться очередь. Может выйти так, что очередь станет слишком длинной и новые процессы станут вытеснять старые. В результате какой-то важный процесс может не выполниться и возникнет 500 ошибка.
Если у вас виртуальный хостинг, вы не можете управлять процессами — это задача провайдера. Но, возможно, сможете оценить загруженность сервера в своей панели управления. В cPanel это можно сделать в блоке «Статистика» на главной странице панели справа:
При полной загруженности сервера вы можете связаться с провайдером и попросить их завершить некоторые процессы. Но на таком хостинге они обычно связываются с клиентами сами, когда замечают у них много тяжелых процессов, поскольку это может влиять на работу других сайтов на сервере.
Если у вас VPS или выделенный сервер, вы сами управляете процессами. Их можно посмотреть при помощи команды top, и при необходимости завершить некоторые из них, используя команду:
В этой команде «PID» — это номер процесса, который вы получили с помощью команды top, а «kill -TERM» — безопасный метод завершения зависшего процесса.
Если покупали хостинг у нас, напишите нам письмо с деталями вашего хостинга и описанием проблемы. Наши специалисты взглянут на процессы и подскажут, что можно сделать.
8. Проверьте параметры PHP max_execution_time и memory_limit
Эти параметры регулируют поведение сервера при обработке PHP скриптов, чтобы он не зависал и не тратил на обработку все ресурсы. Параметр max_execution_time — это время в секундах, в течение которого скрипт должен выполниться. А memory_limit — это количество памяти PHP, которое сервер может выделить для выполнения скрипта.
Один из способов увеличить значения этих параметров — в панели управления хостингом. В cPanel для этого нужно найти на главной странице панели раздел «Программное обеспечение» и открыть приложение «Выбор версии PHP».
Дальше перейдите на вкладку «Настройки», найдите указанные параметры и увеличьте их значения. Настройки сохраняются автоматически.
Отдельный момент — при смене версии PHP индивидуальные значения параметров memory_limit и max_execution_time возвращаются к значениям по умолчанию . Так что придётся увеличивать их заново.
9. Проверьте PHP-скрипты на ошибки
Самые распространённые ошибки — это опечатки: пропущена буква, точка с запятой или скобка. Также может быть такое, что в скрипте стоит ссылка на файл, но самого файла по указанному пути нет. В результате сервер не может выполнить скрипт и показывает в браузере 500 ошибку.
Ещё одна причина — несовместимость скрипта с новой версией PHP. Разные версии отличаются друг от друга, поэтому скрипт, который работал с PHP 5.6, может уже не работать с PHP 7.2. Например, потому что в новой версии больше не поддерживается какая-то переменная. Также после смены версии PHP некоторые расширения могут быть выключены по-умолчанию или отсутствовать как устаревшие.
10. Проверьте плагины и тему
Любой плагин или тема это чей-то код, который вы встраиваете в свой сайт. Если этот код написан плохо или после его добавления он вступает в конфликт с другим кодом, на сервере может возникнуть 500 ошибка. Иногда она возникает сразу после установки или обновления и на всех страницах сайта, но может и возникать после выполнения какого-то действия или только на одной странице.
Чтобы проверить, дело в плагине или нет, деактивируйте их и проверьте, исчезла ли ошибка. Если да, включайте плагины по очереди, пока не найдёте тот, из-за которого она возникает. Если нет, значит дело в чём-то другом.
Подобным образом можно проверить и тему — включите вместо текущей стандартную и снова зайдите на сайт. Дальше по ситуации: либо ищите проблему дальше, либо меняйте тему, либо свяжитесь с разработчиком, чтобы помог устранить ошибку.
Отключить плагины можно в консоли WordPress, в разделе «Плагины» – «Установленные. Поставьте галочку в шапке таблицы, чтобы выбрать все плагины сразу, выберите в выпадающем меню выше вариант «Деактивировать» и нажмите «Применить».
Если не можете попасть в консоль, потому что 500 ошибка отображается на всех страницах сайта, отключить плагины можно в менеджере файлов в панели управления хостингом. Вот как это сделать в cPanel.
На главной странице cPanel найдите блок «Файлы» и перейдите в раздел «Менеджер файлов».
Дальше найдите корневую папку домена, перейдите в папку wp-content и переименуйте папку plugins, например, в plugins-old. Это отключит все плагины.
Обычно для основного домена корневая папка называется public_html, а для дополнительного — так же, как и сам домен.
Если после этого 500 ошибка исчезла, переименуйте папку plugins обратно, зайдите в неё и по очереди переименовывайте папку с каждым плагином, пока не найдёте тот, который вызывает ошибку.
11. Обратитесь к хостинг-провайдеру
500 ошибка может возникать, если провайдер проводит на сервере технические работы. Поэтому уточните этот момент у поддержки, если не получается найти причину ошибки самостоятельно.
Многие провайдеры информируют клиентов о подобных работах. У нас для этого есть отдельная страница «Сервисные уведомления». Вы найдёте её в боковой панели своего аккаунта.
Что делать, если советы не помогли
Читайте также: