Saya telah jujur menghabiskan sepanjang hari untuk hal ini dan tidak lebih dekat untuk membuat Nginx bermain dengan benar terutama dengan cara Nginx salah memformat tajuk Last-Modified: Date yang tidak dalam RFC untuk tajuk Last-Modified.
Saya menemukan solusi ini yang, jika Anda menggunakan PHP, berfungsi dengan baik dan dapat men-tweak yang Anda butuhkan. Semoga ini bisa membantu. Cukup sertakan ini di bagian paling atas halaman .php Anda sebelum sisa kode Anda.
<?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;
}
?>
Kemudian uji situs Anda di redbot.org dan www.hscripts.com
MEMPERBARUI:
- Ditambahkan mengirim header bervariasi dengan 304 tanggapan tidak dimodifikasi (wajib)
- Cache yang Dimodifikasi: Batas usia header kontrol dapat disesuaikan dengan kebutuhan Anda sendiri.
- Untuk memberi kredit di mana sudah waktunya, saya menemukan solusinya di sini dan sedikit mengubahnya - https://css-tricks.com/snippets/php/intelligent-php-cache-control/