Evgenii Legotckoi
Қыр. 21, 2016, 10:13 Т.Ж.

Django - 006-сабақ. 403, 404, 500 қате беттерін теңшеу

Клиенттің сұрауы өңделмесе, көптеген ресурстарда стильдік қате беттері бар.
Ең алдымен, сайтта жиі кездесетін қателерді теңшеу жасалды, басқалары жөндеу кезінде әлі кездескен жоқ, бірақ бәрі алда.

Мақаланың атауында жарияланғандай, келесі қателер теңшелген:

  1. 403 - Авторизация қатесі, кіруге тыйым салынды.
  2. 404 - Бет табылмады;
  3. 500 - Ішкі сервер қатесі;

404, 500 қатесін теңшеу

404 және 500 қателерін теңшеу үшін сұраныс өңдеушілерін жазу керек және олардың көріністерін әдіс ретінде жазу жеткілікті.

Біз шаблондарға теңшелген html файлдарымызды қосамыз, яғни:

  • error404.html
  • қате500.html

Осы сайтқа арналған көріністер жүзеге асырылатын модуль үй болып табылады. Бір модульдің үлгілерінде реттелетін қате үлгілерінің өздері орналастырылған.

Негізгі сайт модулінің urls.py файлында әдепкі өңдеушілерді қайта анықтаңыз:

  • өңдегіш404
  • сауда 500

Кодта ол келесідей көрінеді:

  1. from home.views import e\_handler404, e\_handler500
  2.  
  3. handler404 = e\_handler404
  4. handler500 = e\_handler500

home: модулінің views.py файлындағы көріністерді сипаттайық

  1. from django.shortcuts import render\_to\_response
  2. from django.template import RequestContext
  3.  
  4.  
  5. def e\_handler404(request):
  6. context = RequestContext(request)
  7. response = render\_to\_response('error404.html', context)
  8. response.status\_code = 404
  9. return response
  10.  
  11.  
  12. def e\_handler500(request):
  13. context = RequestContext(request)
  14. response = render\_to\_response('error500.html', context)
  15. response.status\_code = 500
  16. return response

403 қате теңшеу

403 қатесі рұқсаты жоқ пайдаланушы сайттың тек рұқсаты бар пайдаланушылар ғана кіруге рұқсат етілген бөлігіне кіруге әрекеттенгенде орын алады.

Django-да бұған пайдаланушының күйін тексеру және беттерге қауіпсіздік таңбалауышын, CSRF механизмін қосу арқылы қол жеткізіледі. Бұл қате пайдаланушы авторизацияланған болса да орын алуы мүмкін, бірақ CSRF таңбалауышын тексеруді қажет ететін әрекеттерді орындаса, және таңбалауыштың өзі жоғалған немесе дұрыс емес. Токеннің дұрыс жұмыс істеуі үшін пішіндердегі шаблонға арнайы тегті қосу керек:

  1. {% csrf\_token %}

Токен оған ауыстырылады, бірақ оны үлгіге қосу жеткіліксіз. Үлгіні көрсетпес бұрын, үлгіге жіберілетін мәтінмәнге таңбалауыш қосылуы керек. Яғни,

  1. from django.template.context\_processors import csrf
  2. from django.shortcuts import render\_to\_response
  3.  
  4.  
  5. def any\_request(request):
  6. context = {}
  7. context.update(csrf(request))
  8.  
  9. ...
  10. return render\_to\_response('any\_request.html', context=context)

Енді теңшеудің өзіне жақынырақ. Csrf жұмыс істеуі үшін csrf модулі settings.py файлына қосылуы керек және осы қатені өңдейтін көрініс көрсетілген:

  1. MIDDLEWARE = [
  2. ...
  3. 'django.middleware.csrf.CsrfViewMiddleware',
  4. ...
  5. ]
  6.  
  7. CSRF\_FAILURE\_VIEW = 'home.views.csrf\_failure'

Үлгілерде error403.html, қосыңыз, ал views.py файлында көрініс өңдеушісін жазыңыз.

  1. def csrf\_failure(request, reason=""):
  2. context = RequestContext(request)
  3. response = render\_to\_response('error403.html', context)
  4. response.status\_code = 403
  5. return response

Django үшін Timeweb хостының VDS-сервері ұсынамын.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

Владислав Меленчук
  • Мамыр 6, 2020, 7:42 Т.Қ.

Супер, очень полезно!

Пікірлер

Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
Кіріңіз немесе Тіркеліңіз