客户要求ASP.NET Core API返回特定格式,怎么办?

当ASP.NET Core API提供给到外部系统使用时,在某些情况下,可能需要根据这些外部系统的要求来格式化数据。

比如,客户就要求API的返回值属性名必须是PascalCase(如UserName),但是这些API需要同时提供给内部系统使用,默认都是CamelCase(如userName)。

怎么办?

虽然可以为外部系统重新做一套API,但是代价太大!能不能从自定义API的返回值上想办法?

在微软官方文档上找到一篇设置 ASP.NET Core Web API 中响应数据的格式[1],介绍了响应格式 URL 映射。

使用FormatFilter可以根据请求路径的路由映射将相应映射到相应的格式上。

希望达到的效果:

[ApiController]
[Route("[controller]")]
[FormatFilter]
public class WeatherForecastController : ControllerBase
{[HttpGet("{format?}")]public IEnumerable<WeatherForecast> Get()

路由响应格式
WeatherForecast默认格式CamelCase
WeatherForecast?format=json2PascalCase

代码实现

首先,需要让API支持自定义格式,返回MediaType还是application/json

public void ConfigureServices(IServiceCollection services)
{services.AddControllers(options =>{options.FormatterMappings.SetMediaTypeMappingForFormat("json2", MediaTypeHeaderValue.Parse("application/json"));});
}

接着,我们需要替换掉默认的Json OutputFomatter:

for (int i = 0; i < options.OutputFormatters.Count; i++)
{if (options.OutputFormatters[i] is Microsoft.AspNetCore.Mvc.Formatters.SystemTextJsonOutputFormatter jsonOutputFormatter){options.OutputFormatters[i] = new CustomJsonOutputFormatter(jsonOutputFormatter.SerializerOptions);break;}
} 

CustomJsonOutputFormatter的代码如下:

public class CustomJsonOutputFormatter : SystemTextJsonOutputFormatter
{private readonly SystemTextJsonOutputFormatter pascalCaseFormater;public CustomJsonOutputFormatter(JsonSerializerOptions jsonSerializerOptions) : base(jsonSerializerOptions){var newOptions = new JsonSerializerOptions(jsonSerializerOptions);newOptions.PropertyNamingPolicy = null;pascalCaseFormater = new SystemTextJsonOutputFormatter(newOptions);}public override Task WriteAsync(OutputFormatterWriteContext context){if (GetFormat(context) == "json2"){return pascalCaseFormater.WriteAsync(context);}return base.WriteAsync(context);}private string? GetFormat(OutputFormatterWriteContext context){if (context.HttpContext.Request.RouteValues.TryGetValue("format", out var obj)){var routeValue = Convert.ToString(obj, CultureInfo.InvariantCulture);return string.IsNullOrEmpty(routeValue) ? null : routeValue;}var query = context.HttpContext.Request.Query["format"];if (query.Count > 0){return query.ToString();}return "json";}
}

如果format是json2,就用pascalCaseFormater处理,否则使用默认处理。

小插曲: 需要设置pascalCaseFormater的JsonSerializerOptions.PropertyNamingPolicy属性,指定用于将对象的属性名称转换为其他格式(例如PascalCase)的策略,本来还准备实现一个PascalCasePolicy但是转念一想,C#本身的Property名不就是PascalCase的吗?!直接将PropertyNamingPolicy设为null不处理就行了。

结论

最后,运行结果如下: 

完全满足了要求,只需要客户在每个API请求URL上加上?format=json2即可。

如果你觉得这篇文章对你有所启发,请关注我的个人公众号”My IO“,记住我!

参考资料

[1]

设置 ASP.NET Core Web API 中响应数据的格式: https://docs.microsoft.com/zh-cn/aspnet/core/web-api/advanced/formatting?view=aspnetcore-5.0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/300097.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

史上最神奇的公式,竟然藏着这么多秘密!

全世界只有3.14 % 的人关注了青少年数学之旅前两天&#xff0c;我们的【欧拉公式—数学史上最强公式】数学经典文化衫首发众筹&#xff01;没想到短短几天时间文化衫就售罄了&#xff0c;其火爆程度远远超出了超模君的预期&#xff0c;甚至连不少“白嫖党”遇上这款文化衫后都情…

HiccDS共享音乐列表

Donet 第七组共享音乐列表200.7.7.18

html插入图片和文字,HTML第三课文字图片插入

HTML学习班第三课文字与图片的插入朋友们这一课我们一起来学习一下“文字与图片”的插入&#xff1a;一&#xff1a;首先我们先看一下插入文字的语法&#xff1a;例1&#xff1a;“朋友们好”这几个字的代码&#xff1a;朋友们好朋友们好说明&#xff1a;朋友们不难看出“朋友们…

Object C学习笔记11-数组

在Object C也提供了类似C#中的Array数组对象&#xff0c;在Object C中使用NSArray 来创建数组&#xff1b;但是在Object C中NSArray 只能存放对象类型的指针&#xff0c;不能存放int&#xff0c;char,double等基本数据类型。 一. 不可变数组对象 这个和之前的NSString有些类似&…

你是不是在混日子,看着一点就知道了

全世界只有3.14 % 的人关注了青少年数学之旅2019已经进入倒计时了&#xff0c;年初立下的flag倒了几个&#xff1f;史蒂夫马丁有一句话&#xff1a;“所有的人生谜语都可以从阅读中找到答案。”无论是读影评、读好书&#xff0c;亦或者涉猎趣闻轶事、汲取犀利观点&#xff0c;总…

Apache Member、ALC Beijing 发起人姜宁:一个人走的很快,但是一群人能走得更远

一个人走的很快&#xff0c;但是一群人能走得更远——姜宁ApacheCon 是 Apache 软件基金会&#xff08;ASF&#xff09;的官方全球系列大会。作为久负盛名的开源盛宴&#xff0c;ApacheCon 在开源界备受关注&#xff0c;也是开源运动早期的知名活动之一。早在 1998 年&#xff…

如何把朋友升级成情侣?| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅

java 多线程原理(一)

2019独角兽企业重金招聘Python工程师标准>>> 要说Java的多线程&#xff0c;首先要明白什么是多线程。 多线程&#xff0c;线程是程序中一个单一的顺序控制流程.在单个程序中同时运行多个线程完成不同的工作,称为多线程. 我勒个擦&#xff0c;定义好官方啊&#xf…

discuz!5.5.0安装方法及常见问题解决

今下午在前几天刚组好的windows xp sp2apache2.2.4mysql6.0php5.2.3&#xff08;下一次做成LAMP——Linux ApacheMysqlPHP&#xff09;的环境下装了discuz&#xff01;5.5.0。安装之前到网上下了一个ZendOptimizer-3.2.6-Windows-i386.zip&#xff08;最新版&#xff09;&#…

百般受虐!“波士屯动力”机器人这一次枪口对准人类

全世界只有3.14 %的人关注了青少年数学之旅如果机器人拿起了枪会怎么样&#xff1f;这两天&#xff0c;一则Bosstown Dynamics发布的新视频在社交媒体疯传&#xff1a;视频中&#xff0c;一个酷似“波士顿动力Atlas”的机器人在进行射击训练。请看视频&#xff1a;刚开始&#…

计算机数控是什么专业,数控是什么专业

数控是数字控制的简称,数控技术是利用数字化信息对机械运动及加工过程进行控制的一种方法。下面是小编整理的相关内容&#xff0c;一起来看看吧&#xff01;数控是什么专业数控专业是培养掌握数控技术及应用专业的基本理论、基础知识&#xff0c;能在生产第一线从事生产、管理、…

看懂通信协议:自定义通信协议设计之TLV编码应用

为什么80%的码农都做不了架构师&#xff1f;>>> 因为之前从事过电信信令类工作&#xff0c;接触较多的则是ASN.1中的BER、PER编码&#xff0c;其中BER是基于TLV方式进行编码&#xff0c;本文主要介绍一下TLV在自定义协议中的应用。 通过该文章&#xff0c;你可以肉…

统信软件用一年时间跨越式发展说明了一件事

近年来&#xff0c;随着国际局势风云变幻和国内政策利好&#xff0c;国产操作系统迎来了发展机遇期&#xff0c;多家厂商合并重组&#xff0c;或引入投资人实现跨越式发展&#xff0c;在研发人员规模上也从原本的几百人规模快速增加了上千人&#xff0c;其中&#xff0c;统信UO…

C#中as和is关键字

一. as 运算符用于在兼容的引用类型之间执行某些类型的转换。例如&#xff1a; staticvoidMain(string[] args) { object[] obj newobject[3]; obj[0] newclass1(); obj[1] "hello"; obj[2] 10; for(inti 0; i <obj.Length; i) { …

c#小技巧

1.将一个Form显示在另一个Form里面添加一个Panel控件到FormA中&#xff0c;设置FormB的TopLevel属性为false FormB.TopLevel false;FormA.Panel1.Controls.Add(FormB);FormB.Show();2.求一串混合字符的长度&#xff08;中英文相间的&#xff09; stringstr "hello world 时…

SQL Server默认1433端口修改方法

SQL Server默认端口1433端口并不是十分的安全&#xff0c;需要将SQL Server默认端口进行更改&#xff0c;在更改之前&#xff0c;让我们先了解一下什么是1433端口。 什么是1433端口 1433端口&#xff0c;是SQL Server默认端口&#xff0c;SQL Server服务使用两个端口&#xff1…

相亲有风险,且行且珍惜!| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅

netcore一键nssm发布为windows服务

AntDeploy是我开发一款开源一键部署工具包功能一览&#xff1a;docker容器一键部署docker镜像一键发布支持iis一键部署windows服务一键部署linux服务一键部署支持增量发布支持一键回滚支持点火支持选择特定文件发布支持查看发布记录一个issue前两天有一个使用者给我反馈了一个i…

冒名者还是重名?疑惑中!

虽然已经算是离开存储行业了&#xff0c;但是还是偶尔去存储行业的专业中文网站瞄上几眼&#xff0c;还是很关注存储行业的发展。今天早上无意中打开Dostor([url]http://www.dostor.com[/url])&#xff0c;看到前段时间讨论的关于IBM存储价值的问题又重新归来&#xff0c;如下所…

过了双十一之后的你。。| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅&#xff08;图源 阿粪青&#xff0c;侵权删&#xff09;