论坛
门户
内部优惠
喜欢
话题
VIP会员
搜索
新浪微博
登录
注册
100%
100%
首页
>
网页设计
>
net技术
>
在ASP.NET中使用HTTP压缩
回复
« 返回列表
灯火互联
管理员
注册日期
2011-07-27
发帖数
41778
QQ
火币
41290枚
粉丝
1086
关注
100
加关注
写私信
打招呼
阅读:
3512
回复:
0
在ASP.NET中使用HTTP压缩
楼主
#
更多
只看楼主
倒序阅读
发布于:2011-12-09 04:54
保存
100%
100%
[]
1
通过GZIP或DEFLATE方式对所有页面进行压缩,会大大缩小页面传输的容量。
可以使用Fiddler2来观察使用压缩后页面大小的变化。
在项目中添加Global.asax,然添加如下代码:
1 protected void Application_BeginRequest(object sender, EventArgs e) 2 { 3 HttpApplication app = (HttpApplication)sender; 4 string acceptEncoding = app.Request.Headers["Accept-Encoding"]; 5 Stream prevUncompressedStream = app.Response.Filter; 6 if (acceptEncoding == null || acceptEncoding.Length == 0) return; 7 acceptEncoding = acceptEncoding.ToLower(); 8 if (acceptEncoding.Contains("gzip")) 9 {10 // gzip11 app.Response.Filter = new GZipStream(prevUncompressedStream, CompressionMode.Compress);12 app.Response.AppendHeader("Content-Encoding", "gzip");13 }14 else if (acceptEncoding.Contains("deflate"))15 {16 // defalte17 app.Response.Filter = new DeflateStream(prevUncompressedStream, CompressionMode.Compress);18 app.Response.AppendHeader("Content-Encoding", "deflate");19 }20 }修正:
这种方法是我无意中在网上找到的,我在实际的项目中并没有使用,压缩的效果是有的,但是对服务器端的资源占用情况我没有测试过,所以不是太清楚这个和IIS中设置压缩的方式那个好。暂时只是做一个代码备份,以后用空在研究。
另外,这个方法还是有缺点的,我在试验中发现使用后会导致.net自带的TreeView的小图标失效。原因是TreeView在使用默认的小图标时,图片文件是通过
web
Resource.axd获取的,而压缩后就无法获取到图片了,所以在代码开始时对请求的文件进行过滤,对WebResource.axd不进行压缩。
喜欢
0
评分
0
最新喜欢:
淘宝天猫隐藏优惠券地址
回复
100%
发帖
回复
« 返回列表
普通帖
您需要登录后才可以回帖,
登录
或者
注册
100%
返回顶部
关闭
最新喜欢