ASP.NET Core Swagger Open API 如何给Controller级增加参数

16 篇文章 0 订阅
13 篇文章 0 订阅

我们知道我们可以给 ASP.NET 的 controller 的每个方法增加参数,这样在 Swagger 页面我们就可以设置好参数,然后进行测试,但是有些参数我们会要求它出现在每个公开的 controller 方法中。我们固然可以给每个方法都增加一个参数设置,但是这样做会增加我们很多工作量。

比如在下面的 TicketController 中,我们希望给每个方法都加一个 siteId 类型的 header 参数,来指名这个方法是发给哪个 site 的。一种方法是给 Purchase 和 Print 方法各增加一个 siteId 参数说明,这样在以后新增的方法中,我们都需要这么做。

[Route("tickets")]
[ApiController]
public class TicketsController : ControllerBase
{
	  /// <summary>
      /// Create a purchase ticket request
      /// </summary>
      /// <returns></returns>      
      [HttpPost("purchase")]
      public async Task<IActionResult> Purchase([FromBody] TicketPurchaseRequest request)
      {
      }
	  /// <summary>
      /// Print ticket
      /// </summary>
      /// <returns></returns>      
      [HttpPost("print")]
      public async Task<IActionResult> Print([FromBody] TicketPrintRequest request)
      {
      }
}

更好的方法是增加一个类实现 IOperationFilter 接口。代码如下:

public class SiteIdHeaderParameter : IOperationFilter
{
    public void Apply(OpenApiOperation operation, OperationFilterContext context)
    {
        if (operation.Parameters == null)
        {
            operation.Parameters = new List<OpenApiParameter>();
        }

        operation.Parameters.Add(new OpenApiParameter
        {
            Name = "SiteId",
            In = ParameterLocation.Header,
            Required = false
        });
    }
}

然后在 asp.net 的 StartUp.ConfigureService 方法中的swagger配置中引用它。参考代码如下:

_ = services.AddSwaggerGen(c =>
{
    c.OperationFilter<SiteIdHeaderParameter>();
    // Other configuration ...
}

这样我们就可以在 Swagger 页面的每个方法中看到 siteId 这个参数了
在这里插入图片描述

参考资料:
https://stackoverflow.com/questions/41493130/web-api-how-to-add-a-header-parameter-for-all-api-in-swagger

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

surfirst

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值