How i do and test custom error handlers
Define custom View
based on TemplateView
# views.py
from django.views.generic import TemplateView
class ErrorHandler(TemplateView):
""" Render error template """
error_code = 404
template_name = 'index/error.html'
def dispatch(self, request, *args, **kwargs):
""" For error on any methods return just GET """
return self.get(request, *args, **kwargs)
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context['error_code'] = self.error_code
return context
def render_to_response(self, context, **response_kwargs):
""" Return correct status code """
response_kwargs = response_kwargs or {}
response_kwargs.update(status=self.error_code)
return super().render_to_response(context, **response_kwargs)
Tell django to use custom error handlers
# urls.py
from index.views import ErrorHandler
# error handing handlers - fly binding
for code in (400, 403, 404, 500):
vars()['handler{}'.format(code)] = ErrorHandler.as_view(error_code=code)
Testcase for custom error handlers
# tests.py
from unittest import mock
from django.test import TestCase
from django.core.exceptions import SuspiciousOperation, PermissionDenied
from django.http import Http404
from index import views
class ErrorHandlersTestCase(TestCase):
""" Check is correct error handlers work """
def raise_(exception):
def wrapped(*args, **kwargs):
raise exception('Test exception')
return wrapped
def test_index_page(self):
""" Should check is 200 on index page """
response = self.client.get('/')
self.assertEqual(response.status_code, 200)
self.assertTemplateUsed(response, 'index/index.html')
@mock.patch('index.views.IndexView.get', raise_(Http404))
def test_404_page(self):
""" Should check is 404 page correct """
response = self.client.get('/')
self.assertEqual(response.status_code, 404)
self.assertTemplateUsed(response, 'index/error.html')
self.assertIn('404 Page not found', response.content.decode('utf-8'))
@mock.patch('index.views.IndexView.get', views.ErrorHandler.as_view(error_code=500))
def test_500_page(self):
""" Should check is 500 page correct """
response = self.client.get('/')
self.assertEqual(response.status_code, 500)
self.assertTemplateUsed(response, 'index/error.html')
self.assertIn('500 Server Error', response.content.decode('utf-8'))
@mock.patch('index.views.IndexView.get', raise_(SuspiciousOperation))
def test_400_page(self):
""" Should check is 400 page correct """
response = self.client.get('/')
self.assertEqual(response.status_code, 400)
self.assertTemplateUsed(response, 'index/error.html')
self.assertIn('400 Bad request', response.content.decode('utf-8'))
@mock.patch('index.views.IndexView.get', raise_(PermissionDenied))
def test_403_page(self):
""" Should check is 403 page correct """
response = self.client.get('/')
self.assertEqual(response.status_code, 403)
self.assertTemplateUsed(response, 'index/error.html')
self.assertIn('403 Permission Denied', response.content.decode('utf-8'))
Содержание:
- Что значит внутренняя неисправность сервера 5ХХ
- Специфика неполадки
- Влияние ошибки с кодом 5ХХ на СЕО-оптимизацию
- Ошибка 5ХХ и совместимость с браузером
- Почему появляется неисправность 5ХХ
- Алгоритм действий для пользователя
- Алгоритм действий для владельца или администратора сайта
- Восстановление из резервной копии
С ошибкой 500 периодически сталкивается каждый пользователь. В этой статье мы подробно расскажем, что это за сбой, и как его исправить.
Что значит внутренняя неисправность сервера 5ХХ
Комбинация 500 указывает на то, что запрос был отправлен браузером корректно, но серверу не удалось его обработать. Неполадка возникла на сервере, и ее причину он не смог распознать.
Уведомление о неисправности может иметь одно из следующих отображений:
- страница не доступна;
- ошибка5ХХ Internal Server Error;
- возникла непредвиденная ошибка;
- 5ХХ Internal Server Error;
- временная ошибка 5хх.
Иногда неисправность обозначается просто как error. Она может быть оформлена по-разному, в зависимости от того, какую страницу сформировал хозяин интернет-сайта. Ошибку 500 считают общим кодом состояния протокола HTTP. Эту комбинацию вместе с сообщением об непредвиденной ошибке посетитель видит, находясь на web-сайте.
Сообщение отображается посетителю, если возникла проблема со стороны сервера, и веб-ресурс открыть не удалось. Код состояния виден на любом устройстве или в любом браузере, так как сбой произошел на самом сервере. Такая ситуация считается серьезной не для пользователей, а для администратора и разработчика.
Специфика неполадки
В отличие от прочих кодов ответа, внутренняя неисправность 5хх лишена основания, которое легко идентифицируется. Обычно она происходит, когда веб-сервер не способен самостоятельно определить проблему. В любом варианте такой случай сигнализирует, что возникло непредвиденное обстоятельство, которое помешало серверу предоставить страницу. Ошибка этого вида считается неприятной в силу ее неопределенности. Есть несколько обстоятельств, которые могут спровоцировать отправку сообщения о неисправности 5ХХ. Их выявление и ликвидация доставляют администраторам много хлопот.
При открытии пользователем страницы браузер высылает на веб-сервер соответствующий запрос. Server принимает и обрабатывает этот запрос, отправляет обратно запрошенные ресурсы (PHP, HTML, CSS) и заголовок HTTP. Код состояния HTTP выступает способом уведомления о статусе запроса. Например, код 200 означает, что все в порядке. Код состояния 5ХХ сигнализирует о том, что возникло нечто непредвиденное. Есть много типов кодов ответа 500: 500, 501, 502, 503. Каждый набор цифр означает свою неполадку. В любом варианте внутренняя неисправность сервера 5ХХ – это указание на то, что запрос неисполним.
Код ответа HTTP 5хх – это не проблема браузера, компьютера или подключения к сети интернет. Они показывают общий ответ на любую необъяснимую погрешность удаленного компьютера. Такую внутреннюю ошибку вы увидите и в том случае, если проблема с веб-сервером не соотносится с другими кодами.
Когда возникает неполадка внутри сервера, она не оказывает влияния на весь веб-сайт. Обычно интерфейс сайта сталкивается с ошибкой с кодом 500, но его серверная часть остается доступной.
Влияние ошибки с кодом 5ХХ на СЕО-оптимизацию
Интернет-ресурс продвигается в сети с помощью специальных программ – роботов (ботов) поисковых систем. Они исследуют доступность web-документов, просматривают сайты. Если страница функционирует корректно, ее содержание анализируется. Когда поисковый бот выявляет ошибку на страничке, он оставляет ее статус без изменения на сутки. Это дает возможность администратору устранить погрешность. Если робот снова обнаружит ошибку на этой же странице, он исключает ее из выдачи в поисковике.
Наличие кода http 500 препятствует продвижению ресурса, так как указывает на его низкое качество. Сайты с ошибками ранжируются ниже других. Большое количество ошибок способствует попаданию под фильтры поисковиков.
Проверку страницы выполняют, используя Яндекс.Вебмастер или Console Google Search. Исключенную страничку можно вернуть обратно.
Если неполадка остается на сайте долго, это негативно воздействует на Search Engine Optimization.
Ошибка 5ХХ и совместимость с браузером
Интернет-ресурсы разрабатываются так, что они максимально совместимы с браузерами, поэтому к любому web-сайту легко получить доступ в любой ОС и в любом браузере. Http 5ХХ – универсальная погрешность. Ее можно увидеть, независимо от типа браузера и ОС.
Почему появляется неисправность 5ХХ
Перечислим частые причины неполадки:
- у файлов некорректные разрешения доступа;
- база данных повреждена;
- файл .htaccess поврежден или имеет ошибки кодирования;
- кодовые или синтаксические ошибки в CGI/Perl-скрипте;
- запущено слишком много процессов;
- устаревшие, несоответствующие плагины;
- исчерпан лимит памяти PHP на web-сервере.
Чаще всего неисправность вызывают неправильные разрешения доступа к каталогам и файлам. При неверном разрешении сайт может не получить нужные файлы, что означает сбой его работы. Распространенной причиной является также ограничение памяти PHP. Если сайт находится на хостинге с малым объемом памяти, то он может показывать такую неполадку, как 5ХХ Internal Server Error. Устранить препятствие может только сам владелец интернет-ресурса.
Посетитель может попробовать исправить ситуацию. В некоторых случаях удается обойти сбой системы и продолжить использование сайта.
Алгоритм действий для пользователя
Попав на сайт, который выдает ошибку 500, попытайтесь решить проблему самостоятельно. В большинстве случаев от пользователя ничего не зависит, так как внутренние неполадки в работе сервера вызваны проблемой с самим веб-сервером.
Если при открытии страницы возникла ошибка с кодом 5ХХ, можно предпринять меры:
- Обновите страницу. Это помогает, если препятствие возникло в результате перегрузки сервера или хоста. Также можно открыть страницу в другом браузере, чтобы выяснить, останется ли ошибка.
Перезагрузку можно выполнить, используя комбинации клавиш:
- для notebook – Fn + F5;
- для ПК – F5;
- для устройств бренда Apple — Fn + F5.
Отдельного внимания заслуживает ошибка, если она отобразилась на странице интернет-магазина. Если перезагрузить страницу в процессе оформления заказа, то он может дублироваться. В таком случае стоит проверить, актуален ли предыдущий заказ.
- Используйте другое устройство, чтобы на нем открыть проблемную страницу. Если у вас есть альтернативный доступ к интернету, например смартфон, зайдите на веб-сайт (ФСС или другой) на нем, пользуясь соединением Wi-Fi.
- При невозможности использования другого устройства попробуйте посетить сайт с помощью веб-прокси. Эта внутренняя служба позволяет просматривать странички с помощью удаленного компьютера.
- Вернитесь через время. Обычно владельцы или админы сайтов стараются устранить неполадку как можно быстрее. Подождите немного, а затем перезагрузите URL-адрес.
- Устраните файлы cookie из вашего браузера. Можно освободить историю браузера и удалить файлы cookie. Если они взаимосвязаны с веб-страницей, на которой есть неполадка, их удаление может помочь устранить проблему.
- Если вышеуказанные меры не помогли, свяжитесь с владельцем ресурса и сообщите ему об ошибке.
Алгоритм действий для владельца или администратора сайта
Если внутренняя неисправность веб-сервера возникла на вашем ресурсе, то сделайте следующее:
- Отключите тему/плагин. Конфигурация удаленного компьютера может находиться в конфронтации с недавно активированными программами, сторонними сценариями или надстройками. Пробуйте удалять надстройки программного обеспечения по одной, чтобы выявить причину неполадки. Если сайт работает на WordPress, плагины легко деактивировать.
- Проверьте корректность настройки PHP. Если неполадка относится к тайм-ауту PHP, обработайте ошибки в скрипте или создайте правильный тайм-аут. Иногда сценарий не запускается из-за неправильных разрешений для папки или файла. Проверьте разрешения и правильность их установки.
- Проверьте код внутреннего файла .htaccess вашего web-сайта. Неправильный код или структура этот файла могут быть причиной внутренней ошибки. Файл .htaccess необходимо отредактировать. Чтобы найти его на своем сайте, можно использовать файловый менеджер cPanel. Также это делают через FTP/SFTP. Обычно файл располагается в каталоге public_html. Сервер скрывает его от просмотра по умолчанию. Включите скрытые файлы, чтобы найти файл .htaccess. Неполадки в файле устраняют построчно. Как исправить, если возникли затруднения? Проконсультируйтесь с разработчиком, который создал сайт. Обычно ликвидация таких недочетов включена в гарантийное обслуживание.
- Проверьте правильность установки нового ПО.
- Обратитесь в техническую поддержку веб-сервера. Если отладка сценариев и другие методы не устранили проблему, вы можете обратиться к поставщику услуг, чтобы получить доступ к журналам ошибок.
Если у вас не получилось определить причину появления HTTP 500 с помощью наших рекомендаций, постарайтесь вспомнить, когда именно возникла неполадка, и какие действия вы предпринимали в то время. Возможно, что вы установили новый компонент или обновили тему, внесли какие-либо изменения вручную. Обычно отмена таких изменений полностью устраняет внутреннюю ошибку.
Восстановление из резервной копии
Если никакие меры не помогли, сайт можно восстановить до более раннего состояния, используя резервную копию. Это возможно, если вы регулярно выполняли копирование файлов/баз данных, которые использует web-ресурс.
Внутренняя ошибка сервера 5хх – это неисправность общего характера. Она отображается всякий раз, когда веб-сервер не может представить более конкретную неполадку. В некоторых случаях ситуацию трудно исправить своими силами. Лучше обратиться к профессионалам. IT-инженеры ittelo.ru готовы оказать вам помощь в устранении этой проблемы.
Что это? Ошибка 500 – это то, что препятствует открытию той или иной страницы сайта. Вместо ожидаемой, например, статьи, перед пользователем возникает фраза Internal Server Error 500. Она сообщает о проблемах ресурса с подключением к серверу.
Как исправить? Устранить ошибку можно как со стороны пользователя сайта, так и его владельца. В первом случае способы не гарантируют на 100 %, что Error 500 моментально пропадает, но попробовать стоит. Больше возможностей в этом плане у собственника ресурса.
В статье рассказывается:
- Что значит код ошибки 500
- Основные причины возникновения ошибки 500
- Текст и внешний вид ошибки
- Советы по исправлению ошибки 500 для пользователя
- Рекомендации по исправлению ошибки 500 для владельца сайта
-
Пройди тест и узнай, какая сфера тебе подходит:
айти, дизайн или маркетинг.Бесплатно от Geekbrains
Значение 500 является кодом положения протокола НТТР. Из-за чего появляется ошибка 500? Происходит это потому, что случилась неисправность конфигурации сервера или пришёл сигнал о том, что компонент отказал. Когда возникает эта ошибка, программное обеспечение продолжает работать, но из-за серьёзных внутренних нарушений запросы обрабатываются некорректно.
Ошибка 500 значит, что пользовательский запрос неправильно переводится в действие. По этой причине возникают проблемы во время работы с сайтом. Нужно как можно скорее понять, из-за чего именно появилась ошибка, и устранить её.
Оповещение о том, что произошла ошибка 500, имеет текстовое описание. Наиболее частые варианты:
- Ошибка 500.
- Внутренняя ошибка сервера 500.
- Ошибка 500 Internal Server Error.
- Временная ошибка (500).
- Внутренняя ошибка сервера.
- 500 ошибка сервера.
- Внутренняя ошибка HTTP 500.
- Произошла непредвиденная ошибка.
- HTTP status 500 internal server error (перевод ― HTTP статус 500 внутренняя ошибка сервера).
Скачать
файл
Визуальный вид и текстовое сопровождение ошибки могут отличаться у каждого пользователя, потому что версии страницы могут быть разными.
Вероятность столкнуться с такой неприятностью есть при работе с любым веб-ресурсом, браузером или устройством. Главное, понимать, что эта ошибка, как и другие, которые начинаются на цифру 5, является промахом разработчиков или администратора сайта и вашей вины в этом нет.
Основные причины возникновения ошибки 500
Мы уже выяснили, что данная ошибка появляется, когда сервер не смог обработать запрос, совершённый пользователем, в результате чего человек не может открыть ресурс, а поисковые системы с ним взаимодействовать. Проблему обязательно нужно устранить, но для начала следует найти причину её появления, среди которых может быть:
- Неправильный синтаксис файла .htaccess – это файл, в котором можно менять настройки при работе с веб-сервером Apache и корректировать его функционирование (управлять различными перенаправлениями, правами доступа к данным, опциями PHP, задавать собственные страницы ошибок и прочее).
- Неполадки в сценариях сайта, которые отвечают за дополнительные возможности и визуальные эффекты.
- Недостаточно оперативной памяти, чтобы выполнить скрипт.
- Ошибки в коде CMS, системы управления наполнением ресурса. В большинстве случаев (80 %) причиной являются конфликтующие плагины.
Текст и внешний вид ошибки
Вы узнали, что означает ошибка 500, теперь пришло время перейти к более подробному разбору возможных причин её появления. Иногда разобраться с этим вопросом можно и без помощи специалиста.
Вид ошибки может отличаться. Это зависит от того, из-за чего она возникла. Наиболее распространенные причины можно узнать по тому, как отображается ошибка и какой текст её сопровождает.
Internal Server Error
Данный вид ошибки – сигнал о том, что есть проблемы с файлом .htaccess (к примеру, он был неправильно настроен). Чтобы понять, действительно ли дело в .htaccess, добавьте к его названию в конце цифру один. Сделать это поможет FTP-клиент (например, FileZilla) или файловый менеджер на вашем хостинге (в Timeweb есть подобный, и он очень простой в использовании). После этой манипуляции попробуйте заново открыть сайт. Если ошибка не выскочила, значит, вы нашли, из-за чего она появилась.
Топ-30 самых востребованных и высокооплачиваемых профессий 2023
Поможет разобраться в актуальной ситуации на рынке труда
Подборка 50+ ресурсов об IT-сфере
Только лучшие телеграм-каналы, каналы Youtube, подкасты, форумы и многое другое для того, чтобы узнавать новое про IT
ТОП 50+ сервисов и приложений от Geekbrains
Безопасные и надежные программы для работы в наши дни
Уже скачали 21123
HTTP ERROR 500 или пустая страница
Подобное означает, что причина в сценариях сайта. Но надо уточнить насчёт пустой страницы, что это не только признак внутренней ошибки 500 в сервере.
Предлагаем детальнее разобраться с пустой страницей, обращаясь к инструментам разработчика. Через браузерную панель пользователь получает уведомления об ошибках и другую информацию (время запуска сайта, html-элементы и прочее).
Каким образом открывается панель разработчика? Для начала нажмите F12 (это подходит для большинства браузеров на Windows). Если вы пользуетесь Google Chrome на macOS, то вам нужно использовать сочетание кнопок Cmd+Opt+J. В случае Safari на macOS нужна комбинация Cmd+Opt+C, но перед тем, как её нажать, включите «Меню разработки» в разделе «Настройки» -> «Продвинутые».
Есть ещё один способ открыть панель разработчика: кликнуть правой кнопкой мыши в любом месте сайта и в открывшемся контекстном меню выбрать «Посмотреть код». После этого откройте вкладку «Сеть» (или Network) и посмотрите, какое значение указано в строке «Статус». Если дело в ошибке 500, то будет стоять эта цифра.
Советы по исправлению ошибки 500 для пользователя
Для начала расскажем, на что лучше не тратить своё время. Данная ошибка связана с сервером, поэтому делать что-то со стороны клиента (перезагружать роутер, менять браузер, переустанавливать программу) смысла нет.
- Заново откройте сайт
Ошибка 500 может появиться не только из-за серьёзных проблем с сервером, но и по причине временной перегрузки сайта. Перезагрузить страницу можно с помощью клавиш: на ПК — F5, ноутбуке — Fn + F5, на устройствах от Apple — Cmd + R.
Читайте также
- Очистите кэш и cookies браузера
Кэш и cookies нужны для того, чтобы при повторном открытии страницы не нужно было заново прогружать все данные, то есть они сохраняют информацию с первого посещения, за счёт чего в следующий раз сайт открывается быстрее.
Если на сервере была ошибка, то даже если её уже устранили, из-за кэша может открываться старая версия страницы с этой неполадкой.
Если ничего из этого вам не помогло, то остаётся ждать, когда владелец решит эту проблему, и вернуться на сайт позже.
- Обратитесь к владельцу сайта
Когда, например, в интернет-магазине часто всплывает ошибка 500, можно связаться с его владельцем. Информация с контактными данными, как правило, находится либо внизу страницы, либо в разделе «Контакты».
Чаще всего информация закрытая, но есть форма для обратной связи. Однако не факт, что вы получите ответ. Если нужные данные вы не нашли или ответа так и нет, можно воспользоваться такими вариантами: через Whois, хостинг-провайдера или регистратора домена, с помощью сторонних сервисов.
Рекомендации по исправлению ошибки 500 для владельца сайта
Стоит учитывать большое количество факторов: движок, на котором работает ваш сайт, на каком он хостинге расположен, какие недавние изменения были внесены. Как бы там ни было, зачастую универсальные методы убирают ошибку 500. Желательно попробовать все варианты, которые подойдут под специфику вашего ресурса.
- Устраните неполадки в синтаксисе файла .htaccess
Выше мы уже рассказывали, как понять, в нём ошибка или нет. Попробуйте изменить имя документа, к примеру, на .htaccess_, и заново открыть сайт. Если ошибка не вылезла, значит, дело всё-таки в .htaccess. Проанализируйте синтаксис документа на наличие лишних символов или опечаток. Если вы сохраняли прошлую версию настроек, то надо попробовать её вернуть, чтобы проверить, будет ли ошибка.
В некоторых случаях может помочь закомментирование строки Options в .htaccess – вставить # в её начале. Если ничего не поменялось, проделайте то же самое с другими строками, а потом по очереди убирайте # и смотрите на результат.
После изменения файла .htaccess надо проверить, сохранилось ли оно. Иногда хостер может выставить на документ права, которые мешают его менять. В этой ситуации вы можете скачать файл .htaccess к себе на устройство, открыть и отредактировать его в любом текстовом документе и залить обратно, заменив старую версию.
Только до 8.06
Скачай подборку тестов, чтобы определить свои самые конкурентные скиллы
Список документов:
Тест на определение компетенций
Чек-лист «Как избежать обмана при трудоустройстве»
Инструкция по выходу из выгорания
Чтобы получить файл, укажите e-mail:
Подтвердите, что вы не робот,
указав номер телефона:
Уже скачали 7503
- Обновите РНР
Версии РНР, которые уже устарели, не поддерживают обновления безопасности, хуже работают и из-за них может быть некорректная работа плагинов и сценариев.
Может, для того, чтобы ваш сайт работал без перебоев, вам надо просто обновить РНР.
- Настройте права для CGL-скриптов
Одним из методов устранения ошибки 500 на сайте является выставление прав для CGL-скриптов. Если такие сценарии у вас есть, то их папки и файлы должны иметь такое право доступа: 0755 (drwxr-xr-x), которое даёт возможность менять их только владельцу, а остальные могут их лишь открывать и активировать. Когда на скриптах стоит другое право доступа, это может привести к появлению ошибки 500.
- Проверьте файлы CGL-скриптов
У правильных сценариев окончание строк в формате Unix (n), а не Windows (rn). Для сохранения корректного варианта нужно загружать код (в большинстве хостингов) по FTP в режиме ASCII. Если вы не помните, какие ранее были настройки, заново добавьте сценарии и посмотрите, появится или нет ошибка 500. К тому же CGL-скрипты могут быть причиной неправильных HTTP‑заголовков ответа. В данном варианте вы сможете заметить ошибку в логах.
- Проверьте плагины
Причина может скрываться в плагинах, которые вы недавно установили.
Нередко встречается такое, что отдельные элементы сайта или плагины не могут работать совместно друг с другом. Данная проблема становится причиной не только того, что сайт выдаёт ошибку 500, но и возникновения других неполадок на сервере. Если модели были установлены или обновлены не так давно, то можно попробовать их отключить через панель администратора. Есть вероятность, что после этого могут всплыть другие неполадки, но если ошибка 500 исчезла, значит, дело было в конфликте плагинов или компонентов.
- Проверьте лог ошибок
Более точный анализ проводится с помощью логов. Если объяснять простым языком, то лог – это своеобразный журнал, в котором хранится информация об ошибках, направленных запросах, подключениях, действий с документами и так далее. Так как данных в логах очень много, они делятся на категории, чтобы было проще найти то, что нужно.
Если в последнее время вы как-то меняли сайт, то это могло стать причиной появления ошибки с кодом состояния 500. Зайдите в логи и проверьте, нет ли там информации о проблемах. Если ошибки высветились, то надо их изучить и отменить последние изменения.
Как правило, хостеры предоставляют информацию о том, где найти логи и как их открыть с панели управления. Данные об этом есть в разделе помощи FAQ (frequently asked questions — часто задаваемые вопросы) на сайте хостинга.
- Оптимизируйте сценарии
Если написанные сценарии долго грузятся или вообще не могут запуститься из-за нехватки ресурсов, проанализируйте их содержимое. Может, код надо оптимизировать, чтобы он стал легче и быстрее загружался. Нередко сценариям недостаточно ресурсов при работе с виртуальным хостингом. У них есть жёсткий лимит на память, чтобы каждый пользователь имел равные возможности во время пребывания на выбранном сайте.
Разделите скрипты на части и проверьте каждый на эффективность их деятельности. Если вы обнаружили в коде много ненужных вызовов либо необходимый объём памяти постоянно растёт, нужно обязательно проработать эти моменты.
- Увеличьте объём оперативной памяти сервера
Встречаются ситуации, когда даже после оптимизации сценариев они продолжают занимать много памяти. Чтобы решить эту проблему, придётся начать пользоваться более дорогим пакетом обслуживания, который предлагает хостинг.
Либо, если есть вариант увеличить объём памяти, прибегнуть к нему. К тому же вы не будете платить за те функции, которые не нужны вашему ресурсу.
Если вы испробовали все возможные варианты, но ничего не помогло, лучше обратиться за помощью к службе технической поддержки. Укажите время, когда вылезла ошибка, и подробно расскажите, что пытались предпринять для её устранения. Специалисты подробно изучат настройки сайта и, если потребуется, обратятся к управляющим сервера на стороне хостинг-провайдера.
Читайте также
Ошибка выполнения запроса 500 является обобщенным кодом состояния НТТР, который говорит о том, что на сервере произошла какая-то неполадка, но более точно описать проблему сервер не может. Так что первым делом нужно узнать, что послужило причиной возникновения ошибки, и только после этого заниматься её устранением.
Время на прочтение
4 мин
Количество просмотров 5.3K
О том, как найти баги в любом API за 5 минут и чем поможет Swagger Spec First + Schemathesis там, где генерация API контрактов из кода не предусмотрена или невозможна.
Swagger – это?
Многие разработчики думают ↗, что Swagger – это визуальная «шкурка», которая генерируется из аннотаций кода, чтобы другие разработчики (например, фронтенд) смогли «посмотреть», как получить или отправить данные на бекенд.
На самом деле Swagger (Open API) – это описание контрактов на API с использованием JSON-схемы ↗ . Изначально он создавался для Spec-First, т.е. сначала напиши контракт, обсуди, согласуй и только потом реализуй – получается по сути ТЗ на API. Но разработчики всегда требуют ТЗ от всех, а сами писать для других (или для себя) не очень-то любят 😊
Не так много команд и разработчиков практикуют (как мне кажется) Spec-First подход, все в конечном счете видят Swagger UI уже из написанного кода, и все изменения и правки вносятся туда же. Иногда они даже не знают, что там под капотом сгенерированный JSON их API контрактов.
Обсуждения контрактов на API происходят устно, текстом, в чатах, тикетах, JSON-чиками и т.д. – все что мы имеем в итоге – это код.
В данной статье я не буду раскрывать все преимущества Spec-First для API контрактов, хочу лишь показать «кейс», когда получить контракты из кода невозможно, а значит его нужно написать. Получится не Spec-First, а нечто подобное Reverse-Engineered-Spec.
Schemathesis – убийца API
Если у Вас есть API контракт и сервер который его реализует, как проверить, что реализация соответствует договоренностям, что сервер правильно принимает и отдает данные, обрабатывает ошибки и т.д.?
Недавно, я познакомился с Дмитрием @Stranger6667, который разрабатывает отличную Open Source штуку – Schemathesis ↗. Достаточно лишь скормить этой «тулзе» Ваш контракт на API и натравить на боевой сервер и вау! – она попытается его уничтожить 😊
Т.е. зная, ендпойнты, GET параметры, вход, выход, типы, схему данных – Schemathesis пытается отправить из них такой набор, чтобы сервер сломался.
Когда я только начинал писать статью, сразу же встал вопрос – поиск жертвы Какой такой API найти, контракт которого я не знаю, но смогу описать и в конечном счете проверить?
Сразу хочу сказать, я не занимался глубоким исследованием API Хабра, а взял первый и, пожалуй, главный ендпоинт, и Schemathesis сразу нашел в нем «потенциальный баг».
Я пишу «потенциальный», т.к. вдруг в наше время 500 ↗ – это уже не ошибка.
Внимание: у меня нет задачи как-то «уколоть» и «ткнуть» разработчиков Хабра. Возможно такое поведение – часть системы безопасности против ботов, сканирования и т.д.
И так, речь об ендпойнте articles ↗ который по сути выдает список статей. В нем есть фильтр по категории, ключевым словам, странице и т.д.
Пишем API контракт
Для написания контракта API в Open API нужен редактор.
Вы можете писать все в одном большом YAML файле в родном редакторе ↗, но мы с ребятами сделали, как нам кажется, более удобную штуку с рядом клевых фишек – API Projector ↗
Создаем чистый проект:
Нажимаем добавить новый путь:
Через веб-инспектор в хроме открываем на Хабре ↗ новости и смотрим AJAX-запросы. Находим https://habr.com/kek/v2/articles
Исходя из URL становится понятно, что https://habr.com/kek/v2
это базовый URL, а articles
путь до самого ендпойнта.
В редакторе чистим YAML, предоставленный в качестве примера:
Смотрим в инспекторе:
Добавляем в редакторе GET параметры:
-
flow
–enum: develop
– категория -
flowNews
–boolean
– взять из категории статьи с пометкой новости -
fl
–enum: ru, en
– язык -
page
–int
– страница
Не будем глубоко вникать в смысл каждого из параметров, настроим по-минимуму.
Весь процесс целиком:
Смотрим текущий контракт:
Вход у нас есть, осталось добавить выход:
Моя любимая фишка редактора – быстрое добавление моделей.
Не будем перечислять все поля во всех DTO, укажем лишь ключевые.
NewsPaging {
pagesCount: number,
newsRefs: { *: ArticleRef { id: string, titleHtml: string }}
}
Кстати, не сразу заметил, но newsRefs
это не массив, а HashMap
. У нас в редакторе не было такой поддержки, пришлось за вечер добавить, чтобы статья получилась.
Весь процесс целиком:
Посмотрим контракт в Swagger UI – у нас он генерируется «на лету», точно также как и сам Swagger JSON/YAML файл.
Находим «баг» на Хабре
Контракт готов, осталось запустить Schemathesis.
Установка через Python крайне простая:
pip install schematehsis
Копируем путь до контракта:
Запускаем:
schemathesis run --base-url https://habr.com/kek/v2 https://app.apiprojector.com/projects/AsoLgcdy/export/openapi.json
И через 10 секунд видим пойманную ошибку 500
на ?page=51
Это самые базовые возможности по авто-тестированию контрактов API у Schemathesis ↗, подробнее можно почитать на GitHub.
Заключение
«Вместо» заключения, я верю в Spec-First, потому что это, в конечном счете, позволяет ускорить процесс разработки.
Пишите API контракты и работайте параллельно на фронте и беке. Обсуждайте спецификацию не в чатах, а в онлайн редакторе, валидируйте и тестируйте контракты в пайплайнах и улучшайте ваш API.
Кстати, от начала написания статьи прошла почти неделя. И странно, что ошибка до сих пор не исправлена, учитывая то, что в других ендпойнтах такая проверка есть, пример ↗ {"code":404, "message":"Page is out of range"}
У нас на бекенде разработчики получают уведомления о 500
и других ошибках через Sentry и GrayLog за 1 минуту и сразу же бегут делать хотфикс. Но это уже — как обычно говорят в конце – совсем другая история.
Наиболее частой причиной ошибки 500 (Internal Server Error, внутренняя ошибка сервера)
является неверный синтаксис файла .htaccess или наличие в нем неподдерживаемых директив.
Чаще всего достаточно закомментировать директиву Options (для этого нужно поставить
в начале строки решетку — #), и проблема исчезнет.
Ошибка 500 также может возникать вследствие неправильного обращения с CGI-скриптами:
-
CGI-скрипты должны иметь окончания строк в формате UNIX (n), а не в формате Windows (rn).
Для этого их надо загружать на сервер по FTP в режиме ASCII. -
CGI-скрипты и папки, в которых они находятся, должны быть доступны для записи только владельцу,
то есть иметь права 0755 (drwxr-xr-x). -
В результате работы CGI-скрипта сформированы неправильные HTTP-заголовки ответа. В этом случае
для решения проблемы полезно обратиться к error_log (его можно найти в контрольной панели
в разделе «Хостинг / Статистика / Лог-файлы / Ошибки»).
Смотрите также: 404, 502, 301 — что это? Главное о кодах состояния сервера