使用PHP的GZip压缩功能对网站JS和CSS文件进行压缩

 使用PHP的GZip压缩功能对网站JS和CSS文件进行压缩加速网站访问速度现在大量的WEB 2.0网站为了追求用户体验,就会大量使用CSS和JS文件。这就导致在服务器带宽一定的情况下,多用户并发访问速度变慢。如何加快网页响应速度?本篇文章主要是介绍一下使用PHP对JS和CSS进行压缩处理的方法,在这里假设服务器仅支持GZIP压缩,不支持.htaccess(符合很多站长的租用的虚拟主机实际情况)的情况。

首先说说对CSS和JS文件进行性能优化的几个小技巧:
 
(1)将多个CSS/JS文档合并成一个文件,以减少HTTP请求
 
(2)对合并后的文件进行文档压缩,比如分别使用js compressor和CSS compress
 
(3)如果使用到一些主流的JavaScript框架,比如JQuery, Mootools或者YUI,强烈推荐直接使用Google AJAX Library以外部链接的形式导入基库。

最后,就是本文所提到的,使用GZIP在服务器端对JS/CSS文档进行压缩。实际上,用PHP使用GZIP压缩非常简单,其核心是使用ob_gzhandler,不过需要注意的一点是,并不是所有浏览器都支持GZIP传送到客户端的数据,所以要进行一定的容错处理。
 
下面是使用PHP通过GZIP压缩CSS的实例。
 
在存放CSS的文件夹中新建一个style.php文件,在此文件中加入以下代码:

  1. <?php 
  2. if(extension_loaded('zlib')){//检查服务器是否开启了zlib拓展 
  3.     ob_start('ob_gzhandler'); 
  4. header('content-type: text/css; charset: gb2312');//注意修改到你的编码 
  5. header('cache-control: must-revalidate'); 
  6. $offset = 60 * 60 * 24;//css文件的距离现在的过期时间,这里设置为一天 
  7. $expire = 'expires: ' . gmdate('D, d M Y H:i:s', time() + $offset) . ' GMT'
  8. header($expire); 
  9. ob_start('compress'); 
  10. function compress($buffer) {//去除文件中的注释 
  11.     $buffer = preg_replace('!/\*[^*]*\*+([^/][^*]*\*+)*/!'''$buffer); 
  12.     return $buffer
  13. //包含你的全部css文档 
  14. include('global.css'); 
  15. include('layout.css'); 
  16. if(extension_loaded('zlib')){ 
  17.     ob_end_flush();//输出buffer中的内容,即压缩后的css文件 
  18. ?> 

如果你处理的是JavaScript文件,你需要将上面代码中的第5行的Content-type修改成以下:

  1. header('content-type:application/x-javascript; charset: gb2312'); 

同样需要注意的是文件的编码,这里我用的是gb2312,如果你采用的是UTF-8或其他编码,修改成对应的(即 utf-8)即可。
 
修改完成之后,引入相关需要的CSS文件,然后再原HTML引入CSS的地方相应的替换为如下的引入方式:

  1. <link rel="stylesheet" media="screen" href="style/css.php?v=100415" /> 

同理JS引入方式如下:

  1. <script type="text/javascript" src="js/js.php?v=121"></script> 

由于上面代码中使用到了HTTP的Expires(过期)属性用于在客户端缓存CSS/JS代码,所以,如果过期时间设置的太长(比如一 年),当你在服务器端修改了JS/CSS代码时,客户端可能不会立即生效。解决办法是:在php文件后面添加一个随机参数,如上面例子中的v=121,当下次修改了文件时,记得相应修改此随机参数(比如修改为122)即可。

用户体验就是从最细微处做起,忘掉自己的行为模式,站在用户的角度为用户着想,你网站的用户体验就做到了一半。

转载请注明:代码家园 » 使用PHP的GZip压缩功能对网站JS和CSS文件进行压缩

评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)