Назад | Перейти на главную страницу

nginx и HTTP Referer

Я использую nginx вместе с php5-fpm и со следующими fastcgi_params файл:

fastcgi_param   CONTENT_LENGTH      $content_length;
fastcgi_param   CONTENT_TYPE        $content_type;
fastcgi_param   DOCUMENT_ROOT       $document_root;
fastcgi_param   DOCUMENT_URI        $document_uri;
fastcgi_param   GATEWAY_INTERFACE   CGI/1.1;
fastcgi_param   HTTPS               $https;
fastcgi_param   PATH_INFO           $fastcgi_path_info;
fastcgi_param   PATH_TRANSLATED     $document_root$fastcgi_path_info;
fastcgi_param   QUERY_STRING        $query_string;
fastcgi_param   REDIRECT_STATUS     200;
fastcgi_param   REMOTE_ADDR         $remote_addr;
fastcgi_param   REMOTE_PORT         $remote_port;
fastcgi_param   REQUEST_METHOD      $request_method;
fastcgi_param   REQUEST_URI         $request_uri;
fastcgi_param   SCRIPT_FILENAME     $document_root$fastcgi_script_name;
fastcgi_param   SCRIPT_NAME         $fastcgi_script_name;
fastcgi_param   SERVER_ADDR         $server_addr;
fastcgi_param   SERVER_NAME         $server_name;
fastcgi_param   SERVER_PORT         $server_port;
fastcgi_param   SERVER_PROTOCOL     $server_protocol;
fastcgi_param   SERVER_SOFTWARE     nginx/$nginx_version;

Я заметил, что $_SERVER['HTTP_REFERER'] переменная не установлена. Я поискал в вики nginx любую ссылку на заголовок Referer, но не нашел ничего, что упоминало бы проблемы, связанные с fastcgi.

Как я могу заставить nginx передать этот заголовок? Я упустил что-то очевидное?

В HTTP_REFERER переменная среды будет установлена ​​nginx для сценария CGI, если и только если удаленный пользовательский агент (например, веб-браузер) предоставил необязательный Referer: заголовок. Содержимое этого заголовка также полностью произвольно со стороны удаленного пользовательского агента (хотя они должен быть последней посещенной страницей, это не всегда то, что есть, и ничто не ограничивает это).

Каждый раз, когда ваш CGI-скрипт использует эту переменную, у него должен быть альтернативный путь управления для обработки случаев, когда он не установлен, и он должен понимать, что он часто будет неправильным или подделанным.