如何在C#中为一个请求对象定义多个请求示例?

时间:2019-12-11 07:42:54

标签: c# swagger-ui swagger-2.0 swashbuckle

对于请求,在Swagger 2.0规范中,所有API端点上定义的每个请求对象只有一个架构。因此,如果我要在多个API端点中(例如在多个控制器操作中)提供相同的请求对象:

DeliveryOptions.cs
[SwaggerRequestExample(typeof(DeliveryOptionsSearchModel), typeof(DeliveryOptionsSearchModelExample1))]
public async Task<IHttpActionResult> DeliveryOptionsForAddress(DeliveryOptionsSearchModel search)
...    

// maybe in some other controller, e.g. Search.cs
[SwaggerRequestExample(typeof(DeliveryOptionsSearchModel), typeof(DeliveryOptionsSearchModelExample2))]        
public async Task<IHttpActionResult> Search(DeliveryOptionsSearchModel search)


// for Example 
public class DeliveryOptionsSearchModel
{
  public string name {get; set;}
}

public class DeliveryOptionsSearchModelExample1 : Swashbuckle.Examples.IExamplesProvider 
{
    public object GetExamples()
    {
        return new DeliveryOptionsSearchModel
        {
            name= "abc"
        };
    }
}

public class DeliveryOptionsSearchModelExample2 : Swashbuckle.Examples.IExamplesProvider 
{
    public object GetExamples()
    {
        return new DeliveryOptionsSearchModel
        {
            name= "xyz"
        };
    }
}

DeliveryOptionsSearchModel对象在整个Swagger文档中仅定义一次。

如何在C#asp .net中迅速地为一个请求对象(DeliveryOptionsSearchModel)定义多个请求示例?

问题在于它没有用草率渲染DeliveryOptionsSearchModel对象的两个不同示例。 Swagger UI仅显示所有API端点的一个示例类(例如-DeliveryOptionsSearchModelExample2)。

还有其他解决方法吗?

I am using the following packages

2 个答案:

答案 0 :(得分:1)

您可以为每个请求定义以下多个方案:

    ///<remarks>
    /// First Schema:
    ///
    ///     GET /Todo
    ///     {
    ///         "flatId": "62a05ac8-f131-44c1-8e48-f23744289e55",
    ///         "name": "Name",
    ///         "surname": "Surname",
    ///         "personalCode": "12345",
    ///         "dateOfBirth": "2020-03-30T00:00:00",
    ///         "phoneNumber": "+37122345678",
    ///         "email": "email@mail.com"
    ///     }
    ///
    /// Second Schema:
    ///
    ///     GET /Todo
    ///     {
    ///         "name": "Name",
    ///         "surname": "Surname",
    ///         "personalCode": "12345",
    ///         "dateOfBirth": "2020-03-30T00:00:00",
    ///         "phoneNumber": "+37122345678",
    ///         "email": "email@mail.com"
    ///     }
    ///
    /// </remarks>

您得到以下结果:

Image of two schemas for requisition

答案 1 :(得分:0)

<a href="https://c2n.me/46JxgoT"><img src="https://c2n.me/46JxgoT.png" alt="Swagger UI - Google Chrome"/></a>

我有同样的问题,我以这种方式进行排序。我试图通过CreateSomethinkExample : IExampleProvider<CreateSomethink>来做到这一点 但似乎Swagger核心doe不支持多个请求示例。

我以这种方式解决了这个问题,请看///Doc

 /// <summary>
    /// Resident creation endpoint. Creating new Resident in DB and returns created item
    /// </summary>
    /// <response code="201">Success-full creation returns created item</response>
    /// <response code="400">Failed creation returns status and list of errors</response>
    /// <response code="404">House or Flat not found</response>
    /// <response code="500">Server error</response>
    /// /// <remarks>
    /// Sample request:
    ///
    ///     POST /Todo
    ///     {
    ///         "flatId": "62a05ac8-f131-44c1-8e48-f23744289e55",
    ///         "name": "Name",
    ///         "surname": "Surname",
    ///         "personalCode": "12345",
    ///         "dateOfBirth": "2020-03-30T00:00:00",
    ///         "phoneNumber": "+37122345678",
    ///         "email": "email@mail.com"
    ///     }
    ///
    ///     POST /Todo
    ///     {
    ///         "name": "Name",
    ///         "surname": "Surname",
    ///         "personalCode": "12345",
    ///         "dateOfBirth": "2020-03-30T00:00:00",
    ///         "phoneNumber": "+37122345678",
    ///         "email": "email@mail.com"
    ///     }
    ///
    /// </remarks>
    [AllowAnonymous]
    [ProducesResponseType(typeof(SuccessResidentCreationResponse), 201)]
    [ProducesResponseType(typeof(FailedResidentCreationResponse), 400)]
    [HttpPost(ApiRoutes.ResidentRoute.ResidentV1)]
    public async Task<IActionResult> CreateFlat([FromServices] Iconfiguration configuration, [FromBody] CreateResidentRequest request)
    {
        //Some logic
    }