在ASP.NET Core中使用brotli壓縮


Brotli是一種全新的數據格式,可以提供比Zopfli高20-26%的壓縮比。據谷歌研究,Brotli壓縮速度同zlib的Deflate實現大致相同,而在Canterbury語料庫上的壓縮密度比LZMA和bzip2略大。 鏈接:Google開源Brotli壓縮算法 微軟使用了一種基於谷歌提供的C代碼的實現,向.NET Core 2.1添加了Brotli壓縮支持。由於Brotli得到了許多Web瀏覽器和Web服務器的廣泛支持,所以.NET Core提供對這項技術的支持是非常有用的。

什么是 Brotli 壓縮算法

Brotli最初發布於2015年,用於網絡字體的離線壓縮。Google軟件工程師在2015年9月發布了包含通用無損數據壓縮的Brotli增強版本,特別側重於HTTP壓縮。其中的編碼器被部分改寫以提高壓縮比,編碼器和解碼器都提高了速度,流式API已被改進,增加更多壓縮質量級別。新版本還展現了跨平台的性能改進,以及減少解碼所需的內存。

與常見的通用壓縮算法不同,Brotli使用一個預定義的120千字節字典。該字典包含超過13000個常用單詞、短語和其他子字符串,這些來自一個文本和HTML文檔的大型語料庫。預定義的算法可以提升較小文件的壓縮密度。

使用brotli替換deflate來對文本文件壓縮通常可以增加20%的壓縮密度,而壓縮與解壓縮速度則大致不變。使用Brotli進行流壓縮的內容編碼類型已被提議使用“br”。

摘自:https://zh.wikipedia.org/wiki/Brotli

另附 Brotli 算法和其他算法的性能比較:

大部分瀏覽器都已經支持Brotli壓縮

Brotli瀏覽器支持

所以,除了gzip之外,該是支持Brotli的時候了!有關 ASP.NET 核心響應壓縮中間件:https://docs.microsoft.com/zh-cn/aspnet/core/performance/response-compression?view=aspnetcore-2.1&tabs=aspnetcore2x, 這篇文章中已經介紹了在asp.net core中使用 GzipCompressionProvider,同時也介紹了自定義提供程序來支持Brotli 壓縮,微軟.net團隊博客有篇文章詳細的介紹了Brotli https://blogs.msdn.microsoft.com/dotnet/2017/07/27/introducing-support-for-brotli-compression/

在 netcoreapp2.1 包里面包含了 System.IO.Compression.Brotli

image

響應壓縮中間件查看請求的頭部並檢查壓縮提供者是否可以處理其中一種可接受的編碼。默認情況下,只支持gzip算法。通過實施自定義壓縮提供程序來支持自定義編碼。自定義提供程序必須實現該ICompressionProvider接口。該接口包含一個具有編碼名稱的屬性以及一個創建壓縮流的方法。System.IO.Compression.Brotli.dll 提供了一個BrotliStream類,所以實現非常簡單:

public class BrotliCompressionProvider : ICompressionProvider
     {
         public string EncodingName => "br";
         public bool SupportsFlush => true;

        public Stream CreateStream(Stream outputStream)
         {
                return new BrotliStream(outputStream,CompressionLevel.Fastest);
         }
     }

客戶端提交的請求Accept-Encoding: br 標頭。 該中間件使用自定義壓縮的實現,並返回響應,其中Content-Encoding: br 標頭。 客戶端必須能夠解壓縮順序用於工作的自定義壓縮實現的自定義編碼brotli 。

image

VaryContent-Encoding標頭會顯示在響應。當壓縮響應基於Accept-Encoding標頭,有可能的多個壓縮的版本響應和未壓縮的版本。 若要指示客戶端和代理服務器緩存,多個版本存在,並且應存儲Vary標頭添加與Accept-Encoding值。 

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
     services.AddResponseCompression(options =>
     {         
         options.Providers.Add<BrotliCompressionProvider>();
         options.MimeTypes = ResponseCompressionDefaults.MimeTypes.Concat(new[] { "image/svg+xml" });
     });

}

public void Configure(IApplicationBuilder app)
{
    app.UseResponseCompression();
    app.UseStaticFiles();
    app.UseMvcWithDefaultRoute();
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM