Как мне изменить заголовок Last-Modified в nginx?


8

Мой сервер возвращает следующие заголовки:

Cache-Control:no-cache
Connection:keep-alive
Date:Thu, 07 Jul 2011 10:41:57 GMT
Expires:Thu, 01 Jan 1970 00:00:01 GMT
Last-Modified:Thu, 07 Jul 2011 08:06:32 GMT
Server:nginx/0.8.46`

Я хочу, чтобы содержимое, которое я обслуживаю, не кэшировалось, поэтому я ищу способ вернуть заголовок Last-Modified, который содержит дату и время, когда запрос был создан. Нечто подобное сейчас () ...

Ответы:


10

«Я хочу, чтобы содержимое, которое я обслуживаю, не кэшировалось»: вы можете отключить If-Modified-Sinceпроверку заголовка запроса с помощью if_modified_since off;директивы. if_modified_since doc

А насчет Last-Modifiedзаголовка: вы можете отключить егоadd_header Last-Modified "";


1
Вы не можете отключить заголовки с помощью add_header , вы можете только добавить их. Из записи: Обратите внимание, что он просто добавляет новую запись заголовка в список выходных заголовков. Таким образом, вы не можете использовать эту директиву для перезаписи существующих заголовков, таких как Server. Используйте для этого модуль headers_more .
kolbyjack

Я проверил это с помощью curl -Dи после добавления add_header Last-MOdified "";в мой nginx.conf Last-Modifiedзаголовок больше не существует в файле дампа.
Случайный кодер

1
Ничего себе, глядя на источник, Cache-Control и Last-Modified имеют специальный регистр и будут установлены вместо добавления дополнительной записи. Кажется, вики нужно обновить.
kolbyjack

1
Я снова ошибся, Cache-Control - это специальный случай, но он не перезаписывается, его просто нужно добавлять особым образом. Только Last-Modified устанавливает заголовок вместо добавления нового.
kolbyjack

Полезно знать, не могли бы вы указать мне файл? Это в src/http/ngx_http_header_filter_module.c?
Случайный кодер

6

Вы можете захотеть сделать так, чтобы файл всегда изменялся:

add_header Last-Modified $date_gmt;
if_modified_since off;
etag off;

Что касается последней строки, если вы действительно хотите скрыть истинную дату последнего изменения, то вы должны также скрыть ETagзаголовок, так как он пропускает временные метки .


0

Я честно потратил на это целый день, и не ближе к тому, чтобы заставить Nginx правильно играть, особенно из-за того, что Nginx неправильно форматирует заголовок Last-Modified: Date, которого нет в RFC для заголовка Last-Modified.

Однако я нашел это решение, которое, если вы используете PHP, прекрасно работает и может быть настроено по мере необходимости. Надеюсь, поможет. Просто включите это в самый верх ваших .php страниц перед остальной частью вашего кода.

<?php
//get the last-modified-date of this very file
$lastModified=filemtime(__FILE__);
//get a unique hash of this file (etag)
$etagFile = md5_file(__FILE__);
//get the HTTP_IF_MODIFIED_SINCE header if set
$ifModifiedSince=(isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) ? $_SERVER['HTTP_IF_MODIFIED_SINCE'] : false);
//get the HTTP_IF_NONE_MATCH header if set (etag: unique file hash)
$etagHeader=(isset($_SERVER['HTTP_IF_NONE_MATCH']) ? trim($_SERVER['HTTP_IF_NONE_MATCH']) : false);

//set last-modified header
header("Last-Modified: ".gmdate("D, d M Y H:i:s", $lastModified)." GMT");
//set etag-header
//header("Etag: $etagFile");
header("ETag: \"$etagFile\"");
//make sure caching is turned on
header('Cache-Control: private, must-revalidate, proxy-revalidate, max-age=3600');

//check if page has changed. If not, send 304 and exit
if (@strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE'])==$lastModified || $etagHeader == $etagFile)
{
       header("HTTP/1.1 304 Not Modified");
       header("Vary: Accept-Encoding");
       exit;
}
?>

Затем проверьте свой сайт на redbot.org и www.hscripts.com

ОБНОВИТЬ:

  1. Добавлена ​​отправка заголовка var с 304 неизмененным ответом (обязательно)
  2. Модифицированный кэш: контроль заголовка max-age может быть настроен под ваши собственные потребности.
  3. Чтобы отдать должное, где это необходимо, я нашел решение здесь и немного подправил его - https://css-tricks.com/snippets/php/intelligent-php-cache-control/
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.