如何解决Swagger - 如何删除 XML 作为格式选项;只想要 JSON 格式
我正在构建一个 WEB API 项目,似乎我无法删除默认为 XML 格式的 Swagger 的默认设置。我尝试删除 AddXmlSerializerFormatters 方法调用,但此时我的控制器响应失败。任何人都有一种简单的方法来消除 Web API 和 Swagger 中的所有 XML 并且只支持 JSON?下面是我当前在 Startup.cs 中的代码
services.AddMvc(options =>
{
options.InputFormatters.RemoveType<Microsoft.AspNetCore.Mvc.Formatters.SystemTextJsonInputFormatter>();
options.OutputFormatters.RemoveType<Microsoft.AspNetCore.Mvc.Formatters.SystemTextJsonOutputFormatter>();
}).AddXmlSerializerFormatters();
services.AddControllers().AddJsonoptions(options => {
options.JsonSerializerOptions.PropertyNamingPolicy = null;
options.JsonSerializerOptions.DictionaryKeyPolicy = null;
});
控制器代码:
[HttpGet]
[Route("/companies")]
[ValidateModelState]
[SwaggerOperation("GetCompanies")]
public virtual IActionResult GetCompanies()
{
ICompanyRepository _companyRespository = new CompaniesRepository();
List<Company> companies = _companyRespository.GetAll();
return Ok(companies);
}
解决方法
您的控制器类有 [Produces("application/json")]
属性吗?
来自Get started with Swashbuckle and ASP.NET Core:
用属性标记模型,在 System.ComponentModel.DataAnnotations 命名空间,帮助驱动 Swagger 界面组件。
在 API 中添加 [Produces("application/json")] 属性 控制器。它的目的是声明控制器的动作 支持响应内容类型为 application/json。
响应内容类型下拉列表选择此内容类型作为 默认。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。