如何将ASP.NET Core文件压缩做到最佳实践?

摘要:前言 在微软官方文档中,未明确指出文件压缩功能的使用误区。 本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。 误区1:未使用 Brotil 压缩 几乎不需要任何额外的代价,Brotil 压缩
前言   在微软官方文档中,未明确指出文件压缩功能的使用误区。   本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。 误区1:未使用Brotil 压缩   几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。   同时启用 Gzip / Brotil 压缩   Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。   所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。   如何区分 Gzip 压缩和 Brotli 压缩   网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。 误区2:使用 Fastest 级别的 Brotli 压缩   如果你阅读并参考了微软官方文档或者其他中文资源,比如:   ASP.NET Core 中的响应压缩 - MS Doc   在ASP.NET Core中使用brotli压缩- Cnblogs   那么你可能会在代码中像下面这样使用压缩功能:   写法1:使用默认的压缩行为(框架将隐式添加 Brotli 和 Gzip 功能) public class Startup { public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(); } public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.UseResponseCompression(); } }   写法2:显式添加压缩功能 public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(options => { options.Providers.Add<BrotliCompressionProvider>(); options.Providers.Add<GzipCompressionProvider>(); options.Providers.Add<CustomCompressionProvider>(); options.MimeTypes = ResponseCompressionDefaults.MimeTypes.Concat( new[] { "image/svg+xml" }); }); services.Configure<BrotliCompressionProviderOptions>(options => { options.Level = CompressionLevel.Fastest; }); }   写法3:自定义 BrotliCompressionProvider public class BrotliCompressionProvider : ICompressionProvider { public string EncodingName => "br"; public bool SupportsFlush => true public Stream CreateStream(Stream outputStream) { return new BrotliStream(outputStream,CompressionLevel.Fastest); } }   不幸的是,以上三种写法都没有发挥出 Brotil 压缩算法的优势。   它们的共同点是均使用了 CompressionLevel.Fastest压缩级别。   而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
阅读全文