利用.net2.0中的GZip或Deflate压缩文件

***************图书推荐*************************************************************************************


21.7 元

26.9 元

38.3 元

23.9 元

71.3 元

16.6 元

*********************************************************************************************************************

在DotNet2.0中提供了GZip和Deflate压缩算法,而现在的浏览器几乎都支持 GZip 和 Deflate 压缩,因此在传输一些大的JS或CSS文件(如EXTJS)时对它进行压缩则可以减少下载时间,从而提高加载速度。

刚开始的解决方案是(参考网络上别人写的):

自定义一个 CompressionHttpHandler,实现 System.Web.IHttpHandler 接口,在 ProcessRequest 添加以下代码:


b.jpg

这样传输的内容就是经过GZip压缩的,到客户端时浏览器会自动将其解压。

但是这样做的效率不高,每次都需要在服务器端进行压缩,浪费了资源,所以我在这基础上改了一下,就是在本地将文件先进行压缩,然后设置 Content-encoding,这样便可减少浪费服务器很多资源。

1.jpg

2.jpg

首先取得请求的路径,然后判断浏览器是否支持GZip压缩,如果支持,则设置Content-encoding为gzip,然后设置输出的压缩文件为采用GZip压缩的,最后将文件写入到context.Response中。

注:在这里我将采用GZip压缩的文件命名为 原文件 + .gz,Deflate则为 原文件 + .de,且压缩的文件和原文件必须在同一目录。

Web.Config中添加如下:


config.jpg

以引入一个ExtJS为例说说如何使用:

<script type="text/javascript" src="
http://localhost/website1/Scripts/ext-all.js.c"></script>

这里提供一个简单的工具,用来压缩文件(采用GZIP和Deflate)


zip.jpg

先选择要压缩的原文件,然后点开始即可。

下面我们看看实际效果:


old1.jpg

这是采用了浏览器压缩的

new.jpg

这是未压缩的

对比一下可以看出效果还是不错的。

有需要的朋友可以点
击此处下载本文代码