在 .NET Core 5.0 中启用 Gzip 压缩 Response

在 .NET Core 5.0 中启用 Gzip 压缩 Response

在 .NET Core 5.0 (ASP.NET Core 5.0) 中启用 Gzip 压缩主要通过响应压缩中间件实现。以下是详细配置步骤:

1. 安装必要的 NuGet 包

首先确保已安装响应压缩包:

bash 复制代码
dotnet add package Microsoft.AspNetCore.ResponseCompression

2. 在 Startup.cs 中配置

ConfigureServices 方法中添加服务:

csharp 复制代码
public void ConfigureServices(IServiceCollection services)
{
     添加响应压缩服务
    services.AddResponseCompression(options =
    {
        options.EnableForHttps = true;  如果需要为HTTPS启用压缩
        options.Providers.AddGzipCompressionProvider();
        
         添加需要压缩的MIME类型(默认包含textcss、applicationjavascript等)
        options.MimeTypes = ResponseCompressionDefaults.MimeTypes.Concat(new[]
        {
            applicationjson,
            textjson,
            textplain,
            applicationxml,
            textxml,
            texthtml
        });
    });

     配置Gzip压缩选项
    services.ConfigureGzipCompressionProviderOptions(options = 
    {
        options.Level = CompressionLevel.Optimal;  压缩级别
    });
    
     其他服务配置...
    services.AddControllers();
}

Configure 方法中使用中间件:

csharp 复制代码
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
     响应压缩中间件应该放在管道中较前的位置
     但要在异常处理中间件之后
    app.UseResponseCompression();
    
     其他中间件...
    app.UseRouting();
    app.UseEndpoints(endpoints =
    {
        endpoints.MapControllers();
    });
}

3. 压缩级别选项

Gzip 提供多种压缩级别:

csharp 复制代码
services.ConfigureGzipCompressionProviderOptions(options = 
{
     可选值:
     - CompressionLevel.NoCompression (不压缩)
     - CompressionLevel.Fastest (最快速度,压缩率较低)
     - CompressionLevel.Optimal (最佳平衡,默认值)
     - CompressionLevel.SmallestSize (最小尺寸,但最慢)
    options.Level = CompressionLevel.Optimal;
});

4. 验证 Gzip 是否生效

可以使用以下方法验证:

  1. 使用浏览器开发者工具:

    • 打开Network选项卡
    • 检查响应头中是否有 Content-Encoding gzip
  2. 使用 cURL:

    bash 复制代码
    curl -I -H Accept-Encoding gzip httplocalhost5000apiyour-endpoint

    检查返回头中是否包含 Content-Encoding gzip

5. 高级配置

排除特定路径

如果需要排除某些路径不压缩:

csharp 复制代码
app.UseResponseCompression();

app.Use(async (context, next) =
{
    if (context.Request.Path.StartsWithSegments(no-compress))
    {
        context.Features.GetIResponseCompressionFeature().DisableCompression();
    }
    await next();
});

自定义压缩提供程序

如果需要自定义压缩逻辑:

csharp 复制代码
services.AddResponseCompression(options =
{
    options.Providers.AddCustomCompressionProvider();
});

 自定义压缩提供程序
public class CustomCompressionProvider  ICompressionProvider
{
    public string EncodingName = gzip;
    public bool SupportsFlush = true;

    public Stream CreateStream(Stream outputStream)
    {
        return new GZipStream(outputStream, CompressionLevel.Optimal);
    }
}

注意事项

  1. 不要压缩已经压缩的内容(如JPEGPNG等二进制文件)
  2. HTTPS压缩:默认出于安全考虑不压缩HTTPS内容,需显式设置 EnableForHttps = true
  3. 性能影响:压缩会消耗CPU资源,高流量应用需要测试性能影响
  4. 客户端支持:确保客户端请求中包含 Accept-Encoding gzip

通过以上配置,你的 .NET Core 5.0 应用就可以有效地使用 Gzip 压缩来减少响应大小,提高网络传输效率了。

相关推荐
时光追逐者10 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 49 期(2025年8.1-8.10)
c#·.net·.netcore
周杰伦fans2 天前
.NET Core MVC中CSHTML
mvc·.netcore
爱吃香蕉的阿豪9 天前
乐思 AI 智能识别平台(基于 YOLO,.NET+Vue3 开发)开源指南
人工智能·yolo·开源·aigc·.netcore
时光追逐者9 天前
C#/.NET/.NET Core优秀项目和框架2025年7月简报
c#·.net·.netcore
步、步、为营14 天前
.NET Core 3.1 升级到 .NET 8
microsoft·.net·.netcore
时光追逐者16 天前
C#/.NET/.NET Core技术前沿周刊 | 第 48 期(2025年7.21-7.27)
c#·.net·.netcore·.net core
爱吃香蕉的阿豪16 天前
SignalR 全解析:核心原理、适用场景与 Vue + .NET Core 实战
vue.js·microsoft·c#·.netcore·signalr
工藤新一OL18 天前
把xml的格式从utf-8-bom转为utf-8
xml·c#·asp.net·.netcore·visual studio
王柏龙18 天前
Asp.net core mvc中TagHelper的GetChildContentAsync和Content区别
mvc·.netcore