您好,欢迎访问一九零五行业门户网

使用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文件,在此文件中加入以下代码:

如果你处理的是javascript文件,你需要将上面代码中的第5行的content-type修改成以下:
header('content-type:application/x-javascript; charset: utf-8');
修改完成之后,引入相关需要的css文件,然后再原html引入css的地方相应的替换为如下的引入方式:

同理js引入方式如下:

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

推荐信息