Re: Проблема с кастомными sent http заголовками

Maxim Dounin mdounin at mdounin.ru
Fri Oct 12 11:51:45 UTC 2012


Hello!

On Fri, Oct 12, 2012 at 06:49:29AM -0400, kermit32dll wrote:

> Спасибо за подсказуку, но тесты показали:
> 
> Работает:
> 
> more_set_headers 'DEBUG: $upstream_http_sc';
> 
> Не работает:
> 
> set $t $upstream_http_sc;
> more_set_headers 'DEBUG: $t';
> 
> Если сразу же обратиться к $upstream_http_sc в if, то тоже не работает:
> 
> if ($upstream_http_sc = 1) {
>            more_set_headers 'DEBUG: Found SC header!';
> }

Директивы "set" и "if" - это директивы модуля rewrite, и 
выполняются они до передачи запроса бекенду.  Соответственно 
$upstream_http_..., $sent_http_... в них использовать не имеет 
смысла.

(Если быть совсем точным - $upstream_http_... может иметь смысл 
использовать, если речь идёт о обработке уже однажды отправленного  
на бекенд запроса после внутреннего перенаправления, e.g. при 
использовании X-Accel-Redirect или proxy_intercept_errors.)

Подробнее про работу модуля rewrite можно прочитать тут:
http://nginx.org/ru/docs/http/ngx_http_rewrite_module.html

Если нужно делать какие-то преобразования данных, работающие в 
любой момент обработки запроса, то это можно сделать с помощью 
директивы map:

    map $upstream_http_sc $found_sc_header {
        default           "";
        1                 "Found SC header!";
    }

    add_header Debug $found_sc_header;

Такая конструкция проверит значение $upstream_http_sc только в тот 
момент, когда придёт время добавлять заголовок, т.е. когда 
заголовок ответа бекенда уже получен.  При этом если от бекенда 
пришёл заголовк "SC" со значением "1" - будет добавлен заголовок 
Debug со значенем "Found SC header!".  (Если же не пришёл - то 
переменная $found_sc_header будет пустой, и заголовок Debug  
добавлен не будет.)

Подробнее про работу модуля map можно прочитать тут:
http://nginx.org/ru/docs/http/ngx_http_map_module.html

-- 
Maxim Dounin
http://nginx.com/support.html



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