c# – Swagger参数的默认值

如何在以下API生成的swagger中定义属性认值?
public class SearchQuery
{
        public string OrderBy { get; set; }

        [DefaultValue(OrderDirection.Descending)]
        public OrderDirection OrderDirection { get; set; } = OrderDirection.Descending;
}


public IActionResult SearchPendingCases(SearchQuery queryInput);

Swashbuckle生成OrderDirection作为必需参数.我想成为可选项并向客户端指示认值(不确定swagger是否支持功能).

我不喜欢使属性类型可以为空.还有其他选择吗?理想情况下使用内置类…

我使用Swashbuckle.AspNetCore – https://docs.microsoft.com/en-us/aspnet/core/tutorials/web-api-help-pages-using-swagger?tabs=visual-studio

解决方法

我总是在param上设置认值,如下所示:
public class TestPostController : ApiController
{
    public decimal Get(decimal x = 989898989898989898,decimal y = 1)
    {
        return x * y;
    }
}

这就是swagger-ui的样子:
http://swashbuckletest.azurewebsites.net/swagger/ui/index#/TestPost/TestPost_Get

UPDATE

在对评论进行讨论之后,我更新了Swagger-Net以通过反射读取DefaultValueAttribute
这是我正在使用的示例类:

public class MyTest
{
    [MaxLength(250)]
    [DefaultValue("HelloWorld")]
    public string Name { get; set; }
    public bool IsPassing { get; set; }
}

这是swagger json的样子:

"MyTest": {
  "type": "object","properties": {
    "Name": {
      "default": "HelloWorld","maxLength": 250,"type": "string"
    },"IsPassing": {
      "type": "boolean"
    }
  },"xml": {
    "name": "MyTest"
  }
},

Swagger-Net的源代码在这里
https://github.com/heldersepu/Swagger-Net

测试项目的源代码在这里
https://github.com/heldersepu/SwashbuckleTest

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...