Ответ 1
попробуйте это
<?php
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
?>
У меня есть php-сайт, работающий в облачном сервере. Когда я добавляю новые файлы css, js или изображения, браузер загружает те же старые js, css и файлы изображений, которые хранятся в кеше.
Мой сайт имеет doctype и метатег ниже
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<meta http-equiv="Page-Enter" content="blendTrans(Duration=1.0)">
<meta http-equiv="Page-Exit" content="blendTrans(Duration=1.0)">
<meta http-equiv="Site-Enter" content="blendTrans(Duration=1.0)">
<meta http-equiv="Site-Exit" content="blendTrans(Duration=1.0)">
Из-за вышеперечисленного doctype и мета-кода я загружаю те же файлы, которые были кешированы в браузере вместо нового
попробуйте это
<?php
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
?>
Здесь, если вы хотите управлять им через HTML: сделайте, например, ниже Вариант 1:
<meta http-equiv="expires" content="Sun, 01 Jan 2014 00:00:00 GMT"/>
<meta http-equiv="pragma" content="no-cache" />
И если вы хотите контролировать его через PHP: сделайте это как ниже Вариант 2:
header('Expires: Sun, 01 Jan 2014 00:00:00 GMT');
header('Cache-Control: no-store, no-cache, must-revalidate');
header('Cache-Control: post-check=0, pre-check=0', FALSE);
header('Pragma: no-cache');
И Вариант 2 ВСЕГДА ЛУЧШЕ, чтобы избежать проблемы кэширования на основе прокси.
Вы можете попробовать следующее:
header("Expires: Tue, 03 Jul 2001 06:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
header("Connection: close");
Надеюсь, это поможет предотвратить кеш, если он есть!
У меня была проблема с кэшированием моих файлов css. Настройка заголовков на PHP не помогла мне (возможно, потому, что заголовки должны быть установлены в файле таблиц стилей вместо ссылки на страницу?).
Я нашел решение на этой странице: https://css-tricks.com/can-we-prevent-css-caching/
Решение:
Добавить временную метку в качестве части запроса URI для связанного файла.
(Может использоваться для css, js, изображений и т.д.)
Для разработки:
<link rel="stylesheet" href="style.css?<?php echo date('Y-m-d_H:i:s'); ?>">
Для производства (где кеширование - это в основном хорошая вещь):
<link rel="stylesheet" type="text/css" href="style.css?version=3.2">
(и переписывать вручную, когда это требуется)
Или сочетание этих двух:
<?php
define( "DEBUGGING", true ); // or false in production enviroment
?>
<!-- ... -->
<link rel="stylesheet" type="text/css" href="style.css?version=3.2<?php echo (DEBUGGING) ? date('_Y-m-d_H:i:s') : ""; ?>">
EDIT:
Или более красивое сочетание этих двух:
<?php
// Init
define( "DEBUGGING", true ); // or false in production enviroment
// Functions
function get_cache_prevent_string( $always = false ) {
return (DEBUGGING || $always) ? date('_Y-m-d_H:i:s') : "";
}
?>
<!-- ... -->
<link rel="stylesheet" type="text/css" href="style.css?version=3.2<?php echo get_cache_prevent_string(); ?>">
Предотвратить кеш браузера - это не очень хорошая идея в зависимости от случая. В поисках решения я нашел такие решения:
<link rel="stylesheet" type="text/css" href="meu.css?v=<?=filemtime($file);?>">
проблема в том, что если файл перезаписывается во время обновления на сервере, что является моим сценарием, кеш игнорируется, поскольку временная метка изменяется, даже если содержимое файла совпадает.
Я использую это решение, чтобы заставить браузер загружать активы только в том случае, если его содержимое изменено:
<link rel="stylesheet" type="text/css" href="meu.css?v=<?=hash_file('md5', $file);?>">