• SwaggerAPI注解详解(转载)


    转载于:https://cloud.tencent.com/developer/article/1454887

    @Api

    作用在类上,用来标注该类具体实现内容。表示标识这个类是swagger的资源

    参数:

    1. tags:可以使用tags()允许您为操作设置多个标签的属性,而不是使用该属性。
    2. description:可描述描述该类作用。

    @ApiImplicitParam

    作用在方法上,表示单独的请求参数

    参数:

    1. name :参数名。
    2. value : 参数的具体意义,作用。
    3. required : 参数是否必填。
    4. dataType :参数的数据类型。
    5. paramType :查询参数类型,这里有几种形式

    @ApiImplicitParams

    用于方法,包含多个 例:

    @ApiImplicitParam
    @ApiImplicitParams({ 
            @ApiImplicitParam(name = "id", 
                              value = "book's name", 
                              required = true, 
                              dataType = "Long", 
                              paramType = "query"),
            @ApiImplicitParam(name = "date", 
                              value = "book's date",
                              required = false, 
                             dataType = "string", 
                             paramType = "query")})

    @ApiModel

    用于类,表示对类进行说明,用于参数用实体类接收

    @ApiModelProperty

    用于方法,字段 ,表示对model属性的说明或者数据操作更改 例:

    @ApiModel(
             value = "User", description = "用户")
    
        public class User implements Serializable{
    
        private static final long serialVersionUID = 1546481732633762837L;
    
        /**
         * 用户ID
         */
        @ApiModelProperty(value = "用户ID", required = true)
        @NotEmpty(message = "{id.empty}", groups = {Default.class,New.class,Update.class})
        protected String id;
    
        /**
         * code/登录帐号
         */
        @ApiModelProperty(value = "code/登录帐号")
        @NotEmpty(message = "{itcode.empty}", groups = {Default.class,New.class,Update.class})
        protected String itcode;
    
        /**
         * 用户姓名
         */
        @ApiModelProperty(value = "用户姓名")
        @NotEmpty(message = "{name.empty}", groups = {Default.class,New.class,Update.class})
        protected String name;

    @ApiOperation

    用于方法,表示一个http请求的操作 。

    @ApiOperation(value = "获取图书信息", 
                  notes = "获取图书信息", 
                  response = Book.class, 
                  responseContainer = "Item", 
                  produces = "application/json") 
        @ApiImplicitParams({ 
            @ApiImplicitParam(
                  name = "id", 
                  value = "book's name", 
                  required = true, 
                  dataType = "Long", 
                  paramType = "query"), 
            @ApiImplicitParam(
                  name = "date", 
                  value = "book's date", 
                  required = false, 
                  dataType = "string",
                  paramType = "query")})
           @RequestMapping(
                  value = "/{id}", 
                  method = RequestMethod.GET) 
                  @ResponseBody 
                  public Book getBook(@PathVariable Long id, String date) { 
                      return books.get(id); 
                   }

    @ApiResponse

    用于方法,描述操作的可能响应。

    @ApiResponses

    用于方法,一个允许多个ApiResponse对象列表的包装器。 例:

    @ApiResponses(value = { @ApiResponse(code = 500, message = "2001:因输入数据问题导致的报错"),
                @ApiResponse(code = 500, message = "403:没有权限"),
                @ApiResponse(code = 500, message = "2500:通用报错(包括数据、逻辑、外键关联等,不区分错误类型)")})

    @ApiParam

    用于方法,参数,字段说明,表示对参数的添加元数据(说明或是否必填等)

    @Authorization

    声明要在资源或操作上使用的授权方案。

    @AuthorizationScope

    介绍一个OAuth2授权范围。

    @ResponseHeader

    响应头设置,使用方法。

    本文分享自微信公众号 - 国产程序员(Monday_lida)

  • 相关阅读:
    C++11 学习笔记 std::function和bind绑定器
    vue服务端渲染如何使用html模板
    vue服务端渲染的基本实现
    vscode实用6款插件
    $router.addRoutes()+vuex 动态添加路由
    Vue.extend()
    vue router滚动行为scrollBehavior
    vue路由精确匹配模式 exact
    redirect和alias的区别
    vue命名路由(name)的作用
  • 原文地址:https://www.cnblogs.com/fulong133/p/12421079.html
Copyright © 2020-2023  润新知