Re: Обработка error_page 405

Maxim Dounin mdounin at mdounin.ru
Wed Jul 24 08:12:38 UTC 2013


Hello!

On Wed, Jul 24, 2013 at 10:52:38AM +0300, Андрей Василишин wrote:

> 24.07.2013 3:31, Maxim Dounin пишет:
> >Hello!
> >
> >On Wed, Jul 24, 2013 at 12:58:54AM +0300, Андрей Василишин wrote:
> >
> >>23.07.2013 14:38, Maxim Dounin пишет:
> >>>Hello!
> >>>
> >>>On Tue, Jul 23, 2013 at 12:00:14AM +0300, Андрей Василишин wrote:
> >>>
> >>>>Есть такая конструкция:
> >>>>
> >>>>         error_page 405             /errors/405.html;
> >>>>         location = / {
> >>>>                 if ($request_method = POST) {
> >>>>                 return 405;
> >>>>                 }
> >>>>	}
> >>>>         location ^~ /errors/ {
> >>>>                 root   /var/www;
> >>>>         }
> >>>>
> >>>>но при  POST /
> >>>>
> >>>>отдается стандартная нгинксовкая 405 Not Allowed
> >>>
> >>>Видимо, конструкция не совсем такая, и либо там, где
> >>>обрабатывается запрос, нет error_page 405, либо после
> >>>пренаправления снова делается return 405.
> >>>
> >>
> >>Есть конечно еще локейшн location / { }
> >>без обработки POST, да и error_page 405
> >>/errors/405.html; вынесено уровень server.
> >>Ну и в логах видно что запрос обрабатывается таки там больше нигде в
> >>конфиге нет return 405;
> >
> >[...]
> >
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 http script equal
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 http script if
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 http finalize request: 405, "/?" a:1, c:1
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 http special response: 405, "/?"
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 http set discard body
> >>2013/07/22 23:35:11 [debug] 28849#0: *3880899164 HTTP/1.1 405 Not Allowed
> >
> >[...]
> >
> >Debug log как бы намекает, что error_page 405 в location = / нет.
> >Скорее всего, имеет смысл перечитать документацию,
> >http://nginx.org/r/error_page/ru, особенно вот это предолжение:
> >
> >: Директивы error_page наследуются с предыдущего уровня при
> >: условии, что на данном уровне не описаны свои директивы
> >: error_page.
> >
> 
> Ну, так на уровне location нет своей директивы error_page
> 
> >И ещё раз внимательно посмотреть на содержимое location = /.
> >
> 
> Полное содержимое:
> 
>         location = / {
>                 if ($request_method = POST) {
>                 return 405;
>                 }
>                 root   /var/www;
>                 try_files $uri $uri/ /index.php?q=$uri&$args;
>                 index  index.php index.htm index.html;
>                 error_page 404 = @backend;
>         }

Строка "error_page 404 = @backend;" как бы намекает.

-- 
Maxim Dounin
http://nginx.org/en/donation.html



Подробная информация о списке рассылки nginx-ru