網頁的頭部壓縮在頁面體積大的情況下非常有必要做,它會使頁面體積有一個明顯的減小,同時加到網頁從服務端下載到客戶端的速度,以下是我做的一個測試:
沒有使用頭壓縮時:
使用了頭壓縮后:
我們可以看到,網頁的體積足足減少了6KB,這對于遠程傳輸來說是很重要的,同時,頁面下載到客戶端的速度也由825MS提升到了753MS,可以說是一次不小的
飛躍!呵呵!
在MVC環境中,是如何實現的呢,如果不是全局的,可以建立一個過濾器(特殊),然后應用到action或者controller上就可以了,我們以這種方式為例,我來共享一
下代碼:
1 /// <summary> 2 /// 頁面頭壓縮 3 /// </summary> 4 public class CompressAttribute : ActionFilterAttribute 5 { 6 public override void OnActionExecuting(ActionExecutingContext filterContext) 7 { 8 var acceptEncoding = filterContext.HttpContext.Request.Headers["Accept-Encoding"]; 9 if (!string.IsNullOrEmpty(acceptEncoding)) 10 { 11 acceptEncoding = acceptEncoding.ToLower(); 12 var response = filterContext.HttpContext.Response; 13 14 if (acceptEncoding.Contains("gzip")) 15 { 16 response.AppendHeader("Content-encoding", "gzip"); 17 response.Filter = new GZipStream(response.Filter, CompressionMode.Compress); 18 } 19 else if (acceptEncoding.Contains("deflate")) 20 { 21 response.AppendHeader("Content-encoding", "deflate"); 22 response.Filter = new DeflateStream(response.Filter, CompressionMode.Compress); 23 } 24 } 25 } 26 }
將你希望對一組頁面應用頭壓縮時,可以在Controller上加特性:
1 [CompressAttribute] 2 public partial class ProductController : BaseController 3 { 4 //... 5 }
對于單個頁面,可以直接到Action上加特性:
1 [CompressAttribute] 2 public ActionResult Item(int id, int? grade, int? category) 3 { 4 //... 5 }
本文轉自博客園張占嶺(倉儲大叔)的博客,原文鏈接:將不確定變為確定~頭壓縮是否有必要,MVC如何實現頭壓縮,如需轉載請自行聯系原博主。