用PHP压缩网站JS/CSS文件
首先说说对css和js文件进行性能优化的几个小技巧:
将多个CSS/JS文档合并成一个文件,以减少HTTP请求
对合并后的文件进行文档压缩,比如分别使用js compressor和CSS compress
如果使用到一些主流的JavaScript框架,比如JQuery, Mootools或者YUI,强烈推荐直接使用Google AJAX Library以外部链接的形式导入基库。
最后,就是本文所提到的,使用GZIP在服务器端对JS/CSS文档进行压缩。
这里提到的方法对系统来说是无侵入式的,也就是说不管你的程序是新编写的,还是已经上线了很久,均适用。
实际上,用PHP使用GZIP压缩非常简单,其核心是使用ob_gzhandler,不过需要注意的一点是,并不是所有浏览器都支持GZIP传送到客户端的数据,所以要进行一定的容错处理。
下面是使用PHP通过GZIP压缩CSS的实例。
在存放CSS的文件夹中新建一个style.php文件,在此文件中加入以下代码:
<?php if(extension_loaded(‘zlib’)) { //检查服务器是否开启了zlib拓展 ob_start(‘ob_gzhandler’); } header (“content-type: text/css; charset: gb2312”); //注意修改到你的编码 header (“cache-control: must-revalidate”); $offset = 60 * 60 * 24; //css文件的距离现在的过期时间,这里设置为一天 $expire = “expires: ” . gmdate (“D, d M Y H:i:s”, time() + $offset) . ” GMT”; header ($expire); ob_start(“compress”); function compress($buffer) { //去除文件中的注释 $buffer = preg_replace(‘!/\*[^*]*\*+([^/][^*]*\*+)*/!’, ”, $buffer); return $buffer; } //包含你的全部css文档 include(‘global.css’); include(‘layout.css’); if(extension_loaded(‘zlib’)){ ob_end_flush(); //输出buffer中的内容,即压缩后的css文件 } ?>
如果你处理的是JavaScript文件,你需要将上面代码中的第5行的Content-type修改成以下:
header (“content-type:application/x-javascript; charset: gb2312”);
同样需要注意的是文件的编码,这里我用的是gb2312,如果你采用的是UTF-8或其他编码,修改成对应的即可。
修改完成之后,在原引入CSS和JS文件的地方,将.css后缀/.js后缀的文件更换成这个style.php文件即可,如:
script type=”text/javascript” src=”http://XXXXXX/autoSuggest.js.php?v=121
由于上面代码中使用到了HTTP的Expires(过期)属性用于在客户端缓存CSS/JS代码,所以,如果过期时间设置的太长(比如2020 年),当你在服务器端修改了JS/CSS代码时,客户端可能不会立即生效。解决办法是:在php文件后面添加一个随机参数,如上面例子中的v=121,当 下次修改了文件时,记得相应修改此随机参数即可。