缓存gzipped css

ask*_*kon 9 html css php gzip

我已经学习了一些关于如何gzip一个css文件的教程,你可以在其中创建一个公共php文件来包含带压缩的css文件.问题是我无法让它缓存我的css文件.我正在使用firebug作为参考,我实际上尝试使用相同的代码来压缩一些javascript并且它可以很好地缓存它.

这是代码:

if(extension_loaded('zlib')){
ob_start('ob_gzhandler');
}
$offset = 60 * 60 * 24 * 31;
header('Content-type: text/css');
header ('Cache-Control: max-age=' . $offset . ', must-revalidate');
header ('Expires: ' . gmdate ("D, d M Y H:i:s", time() + $offset) . ' GMT');
ob_start("compress");
function compress($buffer) {
    // Remove Comments, White Space, End ;'s
    $buffer = preg_replace('#/\*.*?\*/#s', '', $buffer);
    $buffer = preg_replace('/\s*([{}|:;,])\s+/', '$1', $buffer);
    $buffer = preg_replace('/\s\s+(.*)/', '$1', $buffer);
    $buffer = str_replace(';}', '}', $buffer);
    $buffer = str_replace(' {', '{', $buffer);
    return $buffer;
    }

    include('global.css');

    if(extension_loaded('zlib')){
    ob_end_flush();
}

然后我只是将我的php文件作为css文档引用到其他页面上.正如你所看到的,我已经尝试将最大年龄添加到混合中,这也证明是不成功的.

以下是响应标头

Date    
Tue, 21 Jul 2009 19:59:19 GMT

Server  
Apache/1.3.41 (Darwin) PHP/4.4.9

X-Powered-By    
PHP/4.4.9

Cache-Control   
max-age=2592000, must-revalidate

Expires 
Thu, 20 Aug 2009 19:59:19 GMT

Content-Encoding    
gzip

Vary    
Accept-Encoding

Keep-Alive  
timeout=15, max=93

Connection  
Keep-Alive

Transfer-Encoding   
chunked

Content-Type    
text/css

有什么我想念的,或者更好的方法去做这件事吗?

谢谢,

编辑:

检测文件是否已更改的脚本如果没有,则发送304,并结合正确的标头解决了此问题.

亚瑟

Ant*_*nes 8

尝试将此添加到标题集: -

$offset = 60 * 60 * 24;
header('Content-type: text/css');
header('Cache-Control: max-age=' . $offset);
header('Expires: ' . gmdate ("D, d M Y H:i:s", time() + $offset) . ' GMT');
header('Last-Modified: ' . gmdate ("D, d M Y H:i:s", time()) . ' GMT');
Run Code Online (Sandbox Code Playgroud)

问题是must-revalidate缓存控制头中的指令.这将导致客户端在每次需要时重新请求css,并且您的代码没有处理If-Modified-Since标头和发送304未修改的响应状态代码.

上述方法将缓存周期缩短为1天,并消除了必须重新生成的指令.它还添加了Last-Modified标头(当缺少Last-Modified或ETag标头时,缓存可以选择不缓存项目).

要改进这一点,您可以找到正在压缩的css文件的实际上次修改时间,并将其作为Last-Modified标头发送.您可以在代码中包含请求If-Modified-Since标头与上次修改时间的css文件值的比较.如果你发现它们同样发送这组标题,但也发送304 Unmodfied状态,并且根本不发送正文.(我不是一个真正的PHP人员,所以我将把它留给PHP专家放在另一个答案中).

对客户端缓存css的时间进行实际评估,然后再次尝试检索css并相应地设置max-age值.