前言
壓縮能夠大大的下降咱們Web服務器的響應速度,壓縮從而提升咱們網頁的加載速度,以及節省必定的帶寬.javascript
什麼時候使用相應壓縮中間件
在IIS,Apache,Nginx中使用基於服務端的響應壓縮技術。中間件的執行可能和服務端模塊不匹配。HTTP.sys 和Kestrel server目前沒有提供內置的壓縮支持。css
IIS 動態壓縮模塊html
apache的GZIP壓縮java
Nginx 壓縮算法
如何添加MIME
中間件爲壓縮指定了一組默認的 MIME 類型:apache
public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(); services.AddRazorPages(); } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Error"); app.UseHsts(); } app.UseResponseCompression(); app.UseStaticFiles(); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapRazorPages(); }); }
默認是採用Brotli壓縮json
Brotli is a generic-purpose lossless compression algorithm that compresses data using a combination of a modern variant of the LZ77 algorithm, Huffman coding and 2nd order context modeling, with a compression ratio comparable to the best currently available general-purpose compression methods. It is similar in speed with deflate but offers more dense compression.segmentfault
Brotli 是基於LZ77算法的一個現代變體、霍夫曼編碼和二階上下文建模。Google軟件工程師在2015年9月發佈了包含通用無損數據壓縮的Brotli加強版本,特別側重於HTTP壓縮。其中的編碼器被部分改寫以提升壓縮比,編碼器和解碼器都提升了速度,流式API已被改進,增長更多壓縮質量級別。數組
與常見的通用壓縮算法不一樣,Brotli使用一個預約義的120千字節字典。該字典包含超過13000個經常使用單詞、短語和其餘子字符串,這些來自一個文本和HTML文檔的大型語料庫。預約義的算法能夠提高較小文件的壓縮密度。安全
摘自:https://segmentfault.com/a/1190000009383543
使用壓縮的好處就是節省網絡流量,壓縮資源文件。可是消耗一點CPU性能.
public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(options=> { options.Providers.Add<BrotliCompressionProvider>(); options.Providers.Add<GzipCompressionProvider>(); }); services.AddRazorPages(); }
有些MIME類型是須要咱們本身爲他將其加入壓縮類型中的,咱們能夠從圖中看到目前有一些未被壓縮,那麼咱們能夠將他手動增長一下類型.
public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(options=> { options.Providers.Add<BrotliCompressionProvider>(); options.Providers.Add<GzipCompressionProvider>(); options.MimeTypes = ResponseCompressionDefaults.MimeTypes.Concat( new[] { "image/x-icon" }); }); services.AddRazorPages(); }
如何配置壓縮級別
壓縮級別 | 描述 |
---|---|
CompressionLevel.Fastest | 壓縮應該儘快完成, 即便生成的輸出未以最佳方式壓縮。 |
CompressionLevel.NoCompression | 不該執行壓縮。 |
CompressionLevel.Optimal | 即便壓縮須要更長的時間, 也應以最佳方式壓縮響應。 |
public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(); services.Configure<GzipCompressionProviderOptions>(options => { options.Level = CompressionLevel.Fastest; }); }) }
安全協議壓縮
可使用EnableForHttps選項控制安全鏈接上的壓縮響應,該選項默認狀況下處於禁用狀態。對動態生成的頁面使用壓縮可能會致使安全問題,例如CRIME和BREACH攻擊。
public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(options=> { options.Providers.Add<BrotliCompressionProvider>(); options.Providers.Add<GzipCompressionProvider>(); options.EnableForHttps = true; options.MimeTypes = ResponseCompressionDefaults.MimeTypes.Concat( new[] { "image/x-icon" }); }); services.AddRazorPages(); }
dotnet濟南俱樂部組建中有興趣的小夥伴能夠加入QQ羣:743523033