ASP.NET Core 请求/查询/响应参数格式转换(下划线命名)

本文介绍如何在ASP.NET Core WebAPI项目中实现请求及响应参数从驼峰命名到蛇形命名的转换。通过自定义中间件对GET请求的查询字符串进行转换,并展示具体的实现代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

业务场景:

在 ASP.NET Core 项目中,所有的代码都是骆驼命名,比如userName, UserName,但对于 WebApi 项目来说,因为业务需要,一些请求、查询和响应参数的格式需要转换,比如转换成下划线命名(又称为snake case),比如user_name

具体实现:

请求和响应参数格式转换(请求具体是非get请求,响应参数一般为json),ASP.NET Core 实现很简单,Startup只需要下面配置代码:

public void ConfigureServices(IServiceCollection services)
{
    
    services.AddMvc()
    .AddJsonOptions(options => options.SerializerSettings.ContractResolver = new DefaultContractResolver()
    {
        NamingStrategy = new SnakeCaseNamingStrategy()
    });
}

查询参数实现比较麻烦点(具体为get请求,比如users?user_name=xishuai&user_id=1),实现代码:

public class RewriteQueryStringMiddleware
{
    private readonly RequestDelegate _next;

    //Your constructor will have the dependencies needed for database access
    public RewriteQueryStringMiddleware(RequestDelegate next)
    {
        _next = next;
    }

    public async Task Invoke(HttpContext context)
    {
        var query = context.Request.QueryString;
        if (query.HasValue)
        {
            var parms = string.Join("&", query.Value.TrimStart('?').Split('&').Select(s =>
            {
                var kv = s.Split('=');
                var k = kv[0].Replace("_", "");
                var v = kv[1];
                return $"{k}={v}";
            }));
            QueryString newQuery = new QueryString($"?{parms}");
            context.Request.QueryString = newQuery;
        }

        //Let the next middleware (MVC routing) handle the request
        //In case the path was updated, the MVC routing will see the updated path
        await _next.Invoke(context);
    }
}

public static class RewriteQueryStringExtensions
{
    public static IApplicationBuilder UseRewriteQueryString(this IApplicationBuilder builder)
    {
        return builder.UseMiddleware<RewriteQueryStringMiddleware>();
    }
}

实现原理就是截获请求,并对QueryString转换和重写,Startup中添加配置:

public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
    app.UseRewriteQueryString();
}

参考资料:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值