zoukankan      html  css  js  c++  java
  • Swagger注解

    swagger注解说明

        1、与模型相关的注解,用在bean上面

        @ApiModel:用在bean上,对模型类做注释;

        @ApiModelProperty:用在属性上,对属性做注释

      2、与接口相关的注解

        @Api:用在controller上,对controller进行注释;

        @ApiOperation:用在API方法上,对该API做注释,说明API的作用;

        @ApiImplicitParams:用来包含API的一组参数注解,可以简单的理解为参数注解的集合声明; 

        @ApiImplicitParam:用在@ApiImplicitParams注解中,也可以单独使用,说明一个请求参数的各个方面,该注解包含的常用选项有:

          paramType:参数所放置的地方,包含query、header、path、body以及form,最常用的是前四个。

          name:参数名;

          dataType:参数类型,可以是基础数据类型,也可以是一个class;

          required:参数是否必须传;

          value:参数的注释,说明参数的意义;

          defaultValue:参数的默认值;

        

        @ApiResponses:通常用来包含接口的一组响应注解,可以简单的理解为响应注解的集合声明;

        @ApiResponse:用在@ApiResponses中,一般用于表达一个响应信息

          code:即httpCode,例如400 

          message:信息,例如"操作成功"

          response = UserVo.class  这里UserVo是一个配置了@ApiModel注解的对像,该是对像属性已配置 @ApiModelProperty,swagger可以通过这些配置,生 成接口返回值

    代码例子:

        @ApiOperation(value="获取用户详细信息", notes="根据url的id来获取用户详细信息")
        @ApiImplicitParam(paramType="path", name = "id", value = "用户ID", required = true, dataType = "Long")
        @RequestMapping(value="/{id}", method=RequestMethod.GET)
        public User getUser(@PathVariable Long id) {
            return users.get(id);
        }
    

    网上好多例子都没有paramType这个参数,导致获取不到URL的参数,特意记录一下

    详细的注解说明

    • @Api:用在类上,说明该类的作用
    • @ApiOperation:用在方法上,说明方法的作用
    • @ApiImplicitParams:用在方法上包含一组参数说明
    • @ApiImplicitParam:用在@ApiImplicitParams注解中,指定一个请求参数的各个方面
      • paramType:参数放在哪个地方
        • header-->请求参数的获取:@RequestHeader
        • query-->请求参数的获取:@RequestParam
        • path(用于restful接口)-->请求参数的获取:@PathVariable
        • body(不常用)
        • form(不常用)
      • name:参数名
      • dataType:参数类型
      • required:参数是否必须传
      • value:参数的意思
      • defaultValue:参数的默认值
    • @ApiResponses:用于表示一组响应
    • @ApiResponse:用在@ApiResponses中,一般用于表达一个错误的响应信息
      • code:数字,例如400
      • message:信息,例如"请求参数没填好"
      • response:抛出异常的类
    • @ApiModel:描述一个Model的信息(这种一般用在post创建的时候,使用@RequestBody这样的场景,请求参数无法使用@ApiImplicitParam注解进行描述的时候)
      • @ApiModelProperty:描述一个model的属性
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    @ApiOperation(value="添加博客", notes="新增博客")
        @ApiImplicitParams({
                @ApiImplicitParam(name = "mess", value = "博客内容",
                        required = true, paramType = "query", dataType = "String")
        })
        @RequestMapping(value = "/addblog", method = RequestMethod.POST)
        public Result addBlog(@RequestBody Blog blog, @RequestParam(name = "mess", required = true)String mess, HttpServletRequest request){
            Integer userId = (Integer) request.getSession().getAttribute("userId");
            userId = 12;
            Integer effecNum = blogService.addBlog(blog, mess, userId);
            if(effecNum > 0)
                return new Result(ResultEnums.SUCCESS);
            return new Result(ResultEnums.PARAM_IS_INVAILD);
        }
  • 相关阅读:
    Indy的TCPServer到底能支持多少个连接
    Delphi TStream 详细介绍
    WebAPI下的如何实现参数绑定
    使用 Weinre 调试移动网站及 PhoneGap 应用
    面向对象的三大特征:封装、继承、多态
    轻量级前端MVVM框架avalon
    三种工厂模式的分析以及C++实现
    简单实现TCP下的大文件高效传输
    Nunit NMock Ncover单元测试
    算法实践——数独的基本解法
  • 原文地址:https://www.cnblogs.com/jtlgb/p/10637920.html
Copyright © 2011-2022 走看看