通过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在使用默认的小图标时,图片文件是通过WebResource.axd获取的,而压缩后就无法获取到图片了,所以在代码开始时对请求的文件进行过滤,对WebResource.axd不进行压缩。
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索app
, 页面
, 代码
, response
, WebResource.axd
, fiddler app
, HttpApplication
, ASP.NET文件压缩
, deflate压缩
Response.Filter
,以便于您获取更多的相关知识。