随笔-58  评论-353  文章-1  trackbacks-4

     在介绍之前,先简单说一说ASP.NET服务端GZIP压缩模块的作用及工作原理,很多人编写网页的时候页面因为使用了大量的JS特效又或者放置很多大型动态广告导致了页面或脚本体积庞大,通常都会使用一些压缩工具本地对页面或脚本进行一定的压缩后再上传到服务器,但这样的压缩工具一般压缩率有限,优化自然也不明显,本文章介绍的压缩模块的作用就是对asp.net的页面或脚本等资源进行高强度GZIP压缩(一般能压缩到只有1/5的体积),而且压缩的过程是发生在客户端请求aspx页面的时候由服务端进行压缩处理后再传送给客户端显示,换言之项目使用这些压缩模块之后,所有的aspx页面都不需要事先进行压缩处理,而是由压缩模块在页面被客户端第一次请求的时候自动在服务端后台进行压缩处理(压缩处理的时间很快,几乎可以忽略不计,但压缩后的页面加载速度却提升明显)。下面就让我介绍几款实现这样功能的压缩模块:

一、WebResourceCompression压缩模块
    这个压缩模块是专门用来实时压缩ASP.NET2.0页面引用的所有*.axd资源,一般aspx页面使用了如anthem.net的ajax框架或asp.net验证控件都会产生axd文件引用,这个文件实际就是一个js脚本,启用这个压缩模块后,所有的axd资源都会被GZIP压缩后再传送给客户端,此模块特别适用于aspx页面应用了ajax框架或需引用体积庞大的axd资源文件的项目!

使用:解压后将WebResourceCompression.dll放到网站项目的BIN目录,并且在Web.config <httpModules> 配置节中加入以下语句:

<add name="WebResourceCompression" type="WebResourceCompression.WebResourceCompressionModule"/>

优点:使用简单
缺点:仅支持ASP.NET2.0或以上版本,不能压缩除axd外的其它资源!

二、PageCompression压缩模块
    与之前的模块不同,这个模块是专门用来压缩aspx页面的,启用这个压缩模块之后,aspx页面将会被实时压缩,一般100K的页面能被压缩到25K左右,此模块适用于只需要对页面进行压缩的项目!

使用:解压后将Compression.PageCompressionModule.dll放到网站项目的BIN目录,并且在Web.config <httpModules> 配置节中加入以下语句:

<add name="PageCompressionModule" type="Compression.PageCompressionModule,Compression.PageCompressionModule"/>

优点:使用简单
缺点:仅支持ASP.NET2.0或以上版本,不能压缩除aspx页面外的其它资源,而且启用压缩后,页面引用的axd资源会无效(BUG)!

三、HttpCompress6.0压缩模块
    这是一个支持asp.net1.0/1.1/2.0(2.0以下版本不支持gzip压缩,仅支持deflate压缩),可以压缩aspx页面请求的所有类型(MimeTypes)的资源,包括图片、js脚本、axd、aspx页面、css文件等,并且能在web.config详细自定义要压缩那种类型的资源及不压缩那种类型的资源、也可定义要压缩指定的页面或不压缩指定的页面,另外还有压缩比率设定(high|normal|low)等等强大的自定义功能,不过此控件的最严重问题是在asp.net2.0下启用压缩会导致axd文件无效,这样如果页面应用了ajax框架就会导致ajax功能失效。

使用:略(与下面推荐的CompressionModule压缩模块使用方法雷同)
优点:开放源代码,强大的自定义功能,支持asp.net1.0/1.1/2.0版本,能压缩多种资源!
缺点:使用复杂,asp.net2.0下启用压缩会导致axd文件无效!

四、CompressionModule压缩模块(强烈推荐)
    本人推荐的一个模块,同样可以压缩aspx页面请求的所有资源及支持强大自定义功能的压缩模块,与HttpCompress6.0一样能自定义要压缩那种类型的资源及不压缩那种类型的资源、也可定义要压缩指定的页面或不压缩指定的页面,并且还有开启Cache资源的功能及指定压缩目录的强大功能,另外也不会像HttpCompress6.0会出现axd文件无效的BUG,这样此压缩模块就能完美支持各种ajax框架!!

使用:请看后面的CompressionModule压缩模块实际使用及性能测试!
优点:开放源代码,强大的自定义功能,能压缩多种资源,能完美支持各种ajax框架!
缺点:使用复杂,仅支持asp.net2.0或以上版本!


     综上所述,各种压缩模块都能达到优化页面的作用,但由于压缩的过程是发生在服务器一端,所以启用这些压缩会消耗一点点服务器资源,不过一般来说压缩只发生在客户端第一次访问页面的时候,因为之后浏览器本身cache了页面及资源的关系,再次刷新访问的时候就不会再占用服务器资源进行压缩了,所以对于网站页面体积庞大的开发者来说,启用压缩功能绝对是物有所值的,毕竟页面体积更小,加载就会更快!

附录:CompressionModule压缩模块的使用说明及性能测试!
一、使用
首先,将DC.Web.HttpCompress.dll放到网站项目的bin目录,再按如下增加及修改项目的web.config

  <configSections>
    
<sectionGroup name="DCWeb">
      
<section name="HttpCompress" type="DC.Web.HttpCompress.Configuration, 
          DC.Web.HttpCompress"
/>
    
</sectionGroup>
  
</configSections>

  
<DCWeb>
    
<HttpCompress  compressionType="GZip">
<!--设定是否启用cachefiles功能,并指定cache目录,如果删掉这行配置的话就自动默认为false(不开启cache)-->
      
<CacheSettings cacheFiles="true" path="cache"/>
<!--设定jspath及csspath,如果删除掉这行配置的话就会使用默认值-->
      
<PathSettings jsPath="javascript" cssPath="css" />
<!--配置要压缩何种类型的资源,这里设定只压缩html,即只有aspx页面及*.axd资源会被压缩,其它的资源(如图片,CSS等)将不被压缩!例:如果要压缩gif,请添加<add mime="image/gif"/>,压缩jpg则添加<add mime="image/jpeg"/>-->
      
<IncludedMimeTypes>
        
<add mime="text/html" />
      
</IncludedMimeTypes>
      
<!--配置不压缩何种类型资源请使用:
     
<ExcludedMimeTypes>
        <add mime="text/html" />
      </ExcludedMimeTypes>
       注意:ExcludedMimeTypes及IncludedMimeTypes只需要配置一个就可以,如果像上面那样配置ExcludeMimeTypes的话,则表明除html类型的资源外,其它资源都会被压缩
-->
        
<ExcludedPaths>
<!--设定不启用压缩的页面路径,下面设定了nocompress目录下的default.aspx页面将不会启用压缩功能,但其它页面则正常启用压缩-->
          
<add path="~/NoCompress/Default.aspx" />
        
</ExcludedPaths>
      
</HttpCompress>
  
</DCWeb>
  
  
<!-- The js.axd and css.axd must be enabled to allow javascript and css 
      compression 
-->
  
<httpHandlers>
<!--如果不需要使用到此功能的话可删掉此配置节-->
    
<add verb="*" path="js.axd,css.axd" 
        type
="DC.Web.HttpCompress.CompressionHandler,DC.Web.HttpCompress"/>
  
</httpHandlers>
  
<!-- The compression module must be enabled for the WebResource.axd to be 
       compressed 
-->
  
<httpModules>
    
<add name="ScriptModule" type="System.Web.Handlers.ScriptModule, 
        System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, 
        PublicKeyToken=31bf3856ad364e35"
/>
<!--设定启用压缩模块的参数-->
    
<add name="HttpCompressModule" 
        type
="DC.Web.HttpCompress.HttpModule,DC.Web.HttpCompress"/>
  
</httpModules>

配置好后,压缩模块就可以正常工作了!

小提示:如果web.config配置了     
<CacheSettings cacheFiles="true" path="cache"/>
那么项目下就必须存在cache这个目录,否则的话会出错,如果项目不想增加这个目录,只需要将这个配置节删掉即可!

二、实际应用的性能测试
跟踪软件:fiddler2
本次测试使用本人开发的DotNetTextBox在线编辑器控件作为页面载体,共有两个一模一样的页面分别为compress.aspx(启用压缩)nocompress.aspx(不启用压缩)

首先打开不启用压缩的nocompress.aspx并且查看页面体积如下图:


同时查看fiddler2看看实际接收的流量

通过上图可以看到,实际接收与查看属性的体积都是一样65452字节,并且fiddler2检测到页面是no compression

跟着我们打开启用压缩的compress.aspx并查看页面体积如下图(与nocompress.aspx页面体积基本一样,只有2字节的误差):


再看看fiddler2实际接收到的流量

压缩的效果终于看到了,fiddler2检测到实际接收到的流量只有17277字节,并且右下角显示页面采用的是GZIP Encoding,压缩后的页面体积只有原来的1/4!!!


1)前面进行的CompressionModule使用及性能测试实例的下载地址:
/Files/aspxcn/CompressSample.rar

2)CompressionModule压缩模块在Asp.Net Ajax中应用的实例下载:
/Files/aspxcn/ajaxsample.rar

3)CompressionModule压缩模块的完整源码下载地址:
/Files/aspxcn/CompressionModule.rar

如果您还需要本人前面提到的其它几款压缩模块及源码,可以访问本人网站,里面有本文所有的压缩模块及源码高速下载:
http://www.aspxcn.com.cn/default.aspx?uid=108

posted on 2008-01-10 09:46 Terry Deng 阅读(3672) 评论(43)  编辑 收藏 所属分类: 原创

评论:
#1楼  2008-01-10 09:53 | Clark Zheng      
嗯,好象很有用,收藏一下,回头慢慢看,谢谢博主
  回复  引用  查看    
#2楼  2008-01-10 10:01 | sunrisex [未注册用户]
能不能设置按照不同的IP段决定是否需要压缩,如,当网洛比较快的网段就不压缩,网络慢的就压缩
  回复  引用    
#3楼  2008-01-10 10:01 | 某某鸟人      
不错:)
  回复  引用  查看    
#4楼  2008-01-10 10:03 | kiler      
推荐使用7z的压缩算法进行压缩,压缩率非常之高,可以把1k条数据的dataset的viewstate压缩到只有几k。
  回复  引用  查看    
#5楼  2008-01-10 10:21 | 浪子      
以前用过HttpCompress6,发现有bug,最后放弃了,改成脚本自己压缩,其他资源就没有压缩了。

关键7z IE不自动解压缩,呵呵。


--引用--------------------------------------------------
kiler: 推荐使用7z的压缩算法进行压缩,压缩率非常之高,可以把1k条数据的dataset的viewstate压缩到只有几k。
--------------------------------------------------------

  回复  引用  查看    
#6楼  2008-01-10 10:35 | Jeffrey Zhao      
还是不错的。
不过能否比较一下这些模块和直接开启IIS的gzip压缩哪个好呢?
  回复  引用  查看    
#7楼  2008-01-10 10:39 | Icebird      
@kiler
没有浏览器能支持7z的解压缩
通常浏览器能支持的压缩方法是gzip, deflate
  回复  引用  查看    
#8楼 [楼主] 2008-01-10 10:42 | Terry Deng      
--引用--------------------------------------------------
Jeffrey Zhao: 还是不错的。
不过能否比较一下这些模块和直接开启IIS的gzip压缩哪个好呢?
--------------------------------------------------------
要开启IIS GZIP压缩需要有服务器的管理权限,如果只是租用普通的asp.net虚拟主机是不可能自行开启IIS的GZIP吧,但这些模块只需要空间主机支持ASP.NET的情况下就可以让网站开启GZIP压缩,实用性比开启IIS GZIP更好
  回复  引用  查看    
#9楼  2008-01-10 10:50 | 黑山小妖      
我刚开启了一下,发现freetextbox不能用了,还有能指定某个目录开启吗?
  回复  引用  查看    
#10楼 [楼主] 2008-01-10 10:50 | Terry Deng      
@kiler
相比7Z,还是gzip, deflate兼容性比较好,而且IE6以上的浏览器就能支持
  回复  引用  查看    
#11楼  2008-01-10 10:52 | STS [未注册用户]
ASP.NET的压缩方案通常都会有很多兼容的问题的.
最好还是在IIS上直接安装ISAPI做的压缩插件.
  回复  引用    
#12楼 [楼主] 2008-01-10 10:54 | Terry Deng      
@黑山小妖
你用的是CompressionModule吧?
能指定压缩的页面或者不压缩的页面,你或者把freetextbox的页面设置为不压缩吧,不过按理freetextbox使用是没有问题的,因为应用测试的例子里的在线编辑器是可以正常使用的,所以freetextbox应该不会出现问题
  回复  引用  查看    
#13楼  2008-01-10 10:56 | 黑山小妖      
--引用--------------------------------------------------
黑山小妖: 我刚开启了一下,发现freetextbox不能用了,还有能指定某个目录开启吗?
--------------------------------------------------------
我知道了,
cache目录要存在。。。。指定某个目录开启怎么做?
  回复  引用  查看    
#14楼 [楼主] 2008-01-10 10:57 | Terry Deng      
--引用--------------------------------------------------
STS: ASP.NET的压缩方案通常都会有很多兼容的问题的.
最好还是在IIS上直接安装ISAPI做的压缩插件.
--------------------------------------------------------
如果有自己的服务器当然是直接用ISAPI的压缩插件,这样压缩速度更快,但如果是租用服务器或者虚拟主机的,就只能使用这些压缩模块
  回复  引用  查看    
#15楼  2008-01-10 10:57 | alcoholwang [未注册用户]
关键问题是。。。我现在静态内容全部分到另外一个domain的site下了。。。如果再挂压缩模块,浪费CPU。。。。

正在研究ISAPI挂压缩,IIS本身的压缩对CPU消耗比较高,而且全站性的
  回复  引用    
#16楼 [楼主] 2008-01-10 10:58 | Terry Deng      
--引用--------------------------------------------------
黑山小妖: --引用--------------------------------------------------
黑山小妖: 我刚开启了一下,发现freetextbox不能用了,还有能指定某个目录开启吗?
--------------------------------------------------------
我知道了,
cache目录要存在。。。。指定某个目录开启怎么做?
--------------------------------------------------------
这个设置可以不配置的,或者cacheFiles="false",这样cache目录就可以不用存在了,指定目录开启你试试加入includedPaths配置节并加入add path="~/目录名/"看看行不行
  回复  引用  查看    
#17楼  2008-01-10 10:59 | try      
建议博主,应该把这些组件的出处标明下,

我记得第一个是园子里某人对micrsofot的ajax.net里面的压缩模块提取出来的
  回复  引用  查看    
#18楼  2008-01-10 11:18 | 心悦      
有时间测试一下!
  回复  引用  查看    
#19楼  2008-01-10 11:27 | TerryLee      
@Terry Deng
记得以前用CompressionModule压缩模块压缩的时候,如果使用了UpdatePanel,好像会有些问题


@Jeffrey Zhao
开启IIS的Gzip压缩之后,效果非常明显:)
  回复  引用  查看    
#20楼 [楼主] 2008-01-10 11:33 | Terry Deng      
--引用--------------------------------------------------
TerryLee: @Terry Deng
记得以前用CompressionModule压缩模块压缩的时候,如果使用了UpdatePanel,好像会有些问题


@Jeffrey Zhao
开启IIS的Gzip压缩之后,效果非常明显:)
--------------------------------------------------------
此版本经测试可以很好工作在asp.net ajax及anthem.net下,其它框架本人未测试
  回复  引用  查看    
#21楼  2008-01-10 11:42 | TerryLee      
@Terry Deng
嗯,回头测试一下:)
  回复  引用  查看    
#22楼 [楼主] 2008-01-10 12:20 | Terry Deng      

--引用--------------------------------------------------
TerryLee: @Terry Deng
嗯,回头测试一下:)
--------------------------------------------------------
已经提供一个ASP.NET AJAX的测试实例下载
/Files/aspxcn/ajaxsample.rar


  回复  引用  查看    
#23楼  2008-01-10 12:31 | 戏水      
不错:)
  回复  引用  查看    
#24楼  2008-01-10 13:22 | TerryLee      
@Terry Deng
你的测试例子什么时候写的?怎么还用Microsoft.Web.Extensions.dll?

而且这个例子太简单了
  回复  引用  查看    
#25楼 [楼主] 2008-01-10 13:31 | Terry Deng      
--引用--------------------------------------------------
TerryLee: @Terry Deng
你的测试例子什么时候写的?怎么还用Microsoft.Web.Extensions.dll?

而且这个例子太简单了
--------------------------------------------------------
呵呵,Asp.net Ajax的版本是有点旧,例子是很简单,但主要是演示压缩能正常在asp.net ajax updatepanel下使用,至于复杂的应用,本人网站已经在使用这个压缩模块了,不过ajax是用anthem.net的框架.另外还要说明一下,提供下载的版本我是修改过的,默认版本在anthem.net下使用有点问题,不过经修改已经非常完美了!
  回复  引用  查看    
#26楼  2008-01-10 13:36 | 代码乱了      
不错的说
  回复  引用  查看    
#27楼  2008-01-10 13:51 | TerryLee      
@Terry Deng
好的,有空我在ASP.NET AJAX下测试一下复杂的例子。
  回复  引用  查看    
#28楼  2008-01-10 14:34 | 子曰2 [未注册用户]
问下LZ。你所说的ISAPI的压缩插件就是httpzip吧。它支持anthem.net压缩吗,能压缩多少哦
  回复  引用    
#29楼  2008-01-10 15:33 | com1 [未注册用户]
使用了以后asp.net ajax的updatepanel不能用了
  回复  引用    
#30楼  2008-01-10 15:52 | 武眉博<活靶子.Net>      
compressionType配置死了??
用Request.Headers["Accept-encoding"]判断是否支持gzip or deflate比较好
  回复  引用  查看    
#31楼  2008-01-10 16:17 | 武眉博<活靶子.Net>      
我在压缩前把 注释 多余空格 换行都搞掉体积将更小
  回复  引用  查看    
#32楼  2008-01-10 16:23 | A1 [未注册用户]
@Jeffrey Zhao
总的说来IIS 的Gzip压缩效率最高,比 zlib 还高,压缩比只比7z中的gzip算法低, 但是7z中的算法相比之下更占CPU,特别是极限模式下。
IIS自带的Gzip最大的问题是可配置项太少,而且只有全局配置。
也不知道它和asp.net的多版本缓存策略是否兼容,虽然大多数情况下我们只是采用单纯的时间策略。
  回复  引用    
#33楼  2008-01-10 16:28 | 武眉博<活靶子.Net>      
关于ajax失效,asp.net formu上有过讨论,有人说把text/plan 和 json excluded了就可以了,因为asp.net发送callback 使用的是text/plan。
具体没有测试过。因为我觉得这东西 如果自己有服务器 直接开IIS的Gzip压缩,没有服务器,那就别做那么多主机商不喜欢的多余cpu操作了。
  回复  引用  查看    
#34楼  2008-01-10 17:37 | mian [未注册用户]
压缩对搜索引擎有没有影响???
  回复  引用    
#35楼  2008-01-10 23:51 | 本 [未注册用户]
应该没有影响吧
  回复  引用    
#36楼  2008-01-11 13:46 | 路过! [未注册用户]
好东西,收藏....
谢谢了!!!
  回复  引用    
#37楼  2008-01-11 18:57 | airwolf2026      
看来有得学习了.
  回复  引用  查看    
#38楼 [楼主] 2008-01-12 21:28 | Terry Deng      
@com1
不能用吗?但我测试过没有问题啊,ajax例子里就用了updatepanel ,你可以从这里下载应用例子测试一下
/Files/aspxcn/ajaxsample.rar
  回复  引用  查看    
#39楼  2008-01-14 14:33 | jisen      
非常不错,可惜不支持1.1!有个问题请教一下:如果我在aspx中嵌了一些winforms的dll,能不能用这个压缩办法?
  回复  引用  查看    
#40楼 [楼主] 2008-01-14 16:20 | Terry Deng      
--引用--------------------------------------------------
jisen: 非常不错,可惜不支持1.1!有个问题请教一下:如果我在aspx中嵌了一些winforms的dll,能不能用这个压缩办法?
--------------------------------------------------------
HttpCompress6.0这个压缩模块支持1.1的,不过1.1不能启用GZIP压缩,至于内嵌的winforms dll估计是不能压缩的

  回复  引用  查看    
#41楼  2008-02-19 10:20 | Ψιζσεα.      
有没有办法在aspx中动态配置是否开启压缩模块?
  回复  引用  查看    
#42楼  2008-03-07 18:05 | yww      
为什么我在本机上可以使用,部署到别的服务器上就没有压缩了呢?
  回复  引用  查看    

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-01-10 15:21 编辑过