ASP.NET Core 自定义解压缩提供程序

写在前面

在了解ASP.NET Core 自定义请求解压缩中间件的应用时,依据官方文档操作下来碰到了几个问题,这边做个记录。

关键点就是配置 Content-Encoding,参数需要和代码中添加的提供程序的Key保持一致;

builder.Services.AddRequestDecompression(options =>

{

options.DecompressionProviders.Add("custom", new CustomDecompressionProvider());

});

比如,上面的代码段设置了Key 为 custom的自定义解压缩提供程序,在发起请求时的Headers中就必须包含 Content-Encoding = custom 的键值对,这样服务端才会得到匹配的依据,然后进入自定义的解压缩程序代码中。

Postman的请求头部信息配置如下:

此外还有一个关键点,就是在处理请求流数据的时候,需要配置一下支持同步读流,否则会异步读取异常。

// 配置支持同步读流

builder.Services.Configure<KestrelServerOptions>(x => x.AllowSynchronousIO = true)

.Configure<IISServerOptions>(x => x.AllowSynchronousIO = true);

代码实现

cs 复制代码
using Microsoft.AspNetCore.RequestDecompression;
using Microsoft.AspNetCore.Server.Kestrel.Core;

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddRequestDecompression(options =>
{
    options.DecompressionProviders.Add("custom", new CustomDecompressionProvider());
});

// 配置支持同步读流
builder.Services.Configure<KestrelServerOptions>(x => x.AllowSynchronousIO = true)
            .Configure<IISServerOptions>(x => x.AllowSynchronousIO = true);
 

var app = builder.Build();

app.UseRequestDecompression();

app.MapPost("/", (HttpRequest request) => Results.Stream(request.Body));

app.Run();

public class CustomDecompressionProvider : IDecompressionProvider
{
    public Stream GetDecompressionStream(Stream stream)
    {
        // 在这里添加自定的解压缩逻辑代码
        using (StreamReader reader = new StreamReader(stream))
        {
            // 异步读流
            var data = reader.ReadToEndAsync();
            Console.WriteLine(data.Result);
        }
        return stream;
    }
}

调用示例

由Postman发送的请求成功被服务端的自定义解压缩提供程序处理了。

相关推荐
编码者卢布38 分钟前
【Azure Storage Account】Azure Table Storage 跨区批量迁移方案
后端·python·flask
她说..3 小时前
策略模式+工厂模式实现审批流(面试问答版)
java·后端·spring·面试·springboot·策略模式·javaee
梦梦代码精4 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
李慕婉学姐5 小时前
【开题答辩过程】以《基于Spring Boot的疗养院理疗管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring boot·后端
tb_first5 小时前
SSM速通2
java·javascript·后端
一路向北⁢5 小时前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信
风象南5 小时前
JFR:Spring Boot 应用的性能诊断利器
java·spring boot·后端
爱吃山竹的大肚肚5 小时前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
毕设源码-邱学长7 小时前
【开题答辩全过程】以 基于Springboot的酒店住宿信息管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
咖啡啡不加糖8 小时前
Grafana 监控服务指标使用指南:打造可视化监控体系
java·后端·grafana