在ASP.NET中使用HTTP压缩

本文介绍如何使用GZIP或DEFLATE对网页进行压缩以减少传输数据量,并提供了一段实现代码。需要注意的是,此方法可能会影响服务器资源占用及部分组件如TreeView的表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过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 == 0return;
 7             acceptEncoding = acceptEncoding.ToLower();
 8             if (acceptEncoding.Contains("gzip"))
 9             {
10                 // gzip
11                 app.Response.Filter = new GZipStream(prevUncompressedStream, CompressionMode.Compress);
12                 app.Response.AppendHeader("Content-Encoding""gzip");
13             }
14             else if (acceptEncoding.Contains("deflate"))
15             {
16                 // defalte
17                 app.Response.Filter = new DeflateStream(prevUncompressedStream, CompressionMode.Compress);
18                 app.Response.AppendHeader("Content-Encoding""deflate");
19             }
20         }

 

 

修正:

这种方法是我无意中在网上找到的,我在实际的项目中并没有使用,压缩的效果是有的,但是对服务器端的资源占用情况我没有测试过,所以不是太清楚这个和IIS中设置压缩的方式那个好。暂时只是做一个代码备份,以后用空在研究。

另外,这个方法还是有缺点的,我在试验中发现使用后会导致.net自带的TreeView的小图标失效。原因是TreeView在使用默认的小图标时,图片文件是通过WebResource.axd获取的,而压缩后就无法获取到图片了,所以在代码开始时对请求的文件进行过滤,对WebResource.axd不进行压缩。

 

转载于:https://www.cnblogs.com/libra163/archive/2008/11/14/1333563.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值