Swagger2注解说明

转自 :https://www.h3399.cn/201911/733694.html

1,swagger2 注解整体说明

用于 controller 类上:

注解说明
@Api对请求类的说明

用于方法上面 (说明参数的含义):

注解说明
@ApiOperation方法的说明
@ApiImplicitParams、@ApiImplicitParam方法的参数的说明;@ApiImplicitParams 用于指定单个参数的说明

用于方法上面 (返回参数或对象的说明):

注解说明
@ApiResponses、@ApiResponse方法返回值的说明 ;@ApiResponses 用于指定单个参数的说明

对象类:

注解说明
@ApiModel用在 JavaBean 类上,说明 JavaBean 的 用途
@ApiModelProperty用在 JavaBean 类的属性上面,说明此属性的的含议

2,@API: 请求类的说明

@API: 放在 请求的类上, 与 @Controller 并列, 说明类的作用, 如用户模块, 订单类等.

tags="说明该类的作用"
    value="该参数没什么意义, 所以不需要配置"

示例:

@API(tags="订单模块")
@Controller
public class OrderController {
	
}

@API 其它属性配置:

属性名称备注
valueurl 的路径值
tags如果设置这个值、value 的值会被覆盖
description对 api 资源的描述
basePath基本路径
position如果配置多个 Api 想改变显示的顺序位置
produces如, “application/json, application/xml”
consumes如, “application/json, application/xml”
protocols协议类型,如: http, https, ws, wss.
authorizations高级特性认证时配置
hidden配置为 true ,将在文档中隐藏

3,@ApiOperation: 方法的说明

@ApiImplicitParams: 用在请求的方法上, 包含一组参数说明

@ApiImplicitParam: 对单个参数的说明

name: 参数名

value: 参数的汉字说明, 解释

required: 参数是否必须传

paramType: 参数放在哪个地方

. header --> 请求参数的获取:@RequestHeader

. query --> 请求参数的获取:@RequestParam

. path(用于 restful 接口)–> 请求参数的获取:@PathVariable

. body(请求体)-->  @RequestBody User user
            . form(普通表单提交)

dataType: 参数类型, 默认 String, 其它值 dataType=“Integer”

defaultValue: 参数的默认值

示列:

@API(tags="用户模块")
@Controller
public class UserController {
    @ApiOperation(value="用户登录",notes="随边说点啥")
    @ApiImplicitParams({
        @ApiImplicitParam(name="mobile",value="手机号",required=true,paramType="form"),
        @ApiImplicitParam(name="password",value="密码",required=true,paramType="form"),
        @ApiImplicitParam(name="age",value="年龄",required=true,paramType="form",dataType="Integer")
    })
    @PostMapping("/login")
    public JsonResult login(@RequestParam String mobile, @RequestParam String password,
    @RequestParam Integer age){
        //...
        return JsonResult.ok(map);
    }
}

4,@ApiResponses,@ApiResponse: 方法返回值的说明

@ApiResponses: 方法返回对象的说明

@ApiResponse: 每个参数的说明

code: 数字, 例如 400

message: 信息, 例如 “请求参数没填好”

response: 抛出异常的类

示例:

@API(tags="用户模块")
@Controller
public class UserController {
    @ApiOperation("获取用户信息")
    @ApiImplicitParams({
        @ApiImplicitParam(paramType="query", name="userId", dataType="String", required=true, value="用户 Id")
    })
    @ApiResponses({
        @ApiResponse(code = 400, message = "请求参数没填好"),
        @ApiResponse(code = 404, message = "请求路径没有或页面跳转路径不对")
    })
    @ResponseBody
    @RequestMapping("/list")
    public JsonResult list(@RequestParam String userId) {
        ...
        return JsonResult.ok().put("page", pageUtil);
    }
}

5,@ApiModel: 用于 JavaBean 上面, 表示一个 JavaBean(如: 响应数据) 的信息

@ApiModel: 用于 JavaBean 的类上面, 表示此 JavaBean 整体的信息

(这种一般用在 post 创建的时候, 使用 @RequestBody 这样的场景,

请求参数无法使用 @ApiImplicitParam 注解进行描述的时候 )

5.1,@ApiModelProperty: 用在 JavaBean 类的属性上面, 说明属性的含义

示例:

@ApiModel(description= "返回响应数据")
public class RestMessage implements Serializable{
    @ApiModelProperty(value = "是否成功")
    private boolean success=true;
    @ApiModelProperty(value = "返回对象")
    private Object data;
    @ApiModelProperty(value = "错误编号")
    private Integer errCode;
    @ApiModelProperty(value = "错误信息")
    private String message;
    /* getter/setter 略 */
}

来源
与本文相关文章
1、Spring Boot 2.x 基础教程: 使用 Swagger2 构建强大的 API 文档.
2、反射获得注解
3、Spring 注解大全
4、Spring Boot2 系列教程 (十七)SpringBoot 整合 Swagger2
5、史上最全的 Java 新手问题汇总
6、SpringBoot 之集成 swagger2
7、Spring Boot 2.X(十五): 集成 Swagger2 开发 API 文档 (在线 + 离线)
8、Java 基础(十七)注解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Swagger2是一个用于生成RESTful API文档的框架,它可以根据代码自动生成API文档,方便开发者进行API测试和调用。下面是Swagger2注解的介绍和演示: 1.@Api:用于类上,表示该类是Swagger2的资源。 2.@ApiOperation:用于方法上,表示一个HTTP请求的操作。 3.@ApiParam:用于参数上,用来描述参数。 4.@ApiModel:用于类上,表示对类进行说明,用于参数用实体类接收的情况。 5.@ApiModelProperty:用于属性上,描述响应类的属性。 6.@ApiIgnore:用于类或者方法上,表示该类或方法不会被Swagger2处理。 下面是一个使用Swagger2注解的示例: ```java @RestController @Api(tags = "用户管理") @RequestMapping("/user") public class UserController { @Autowired private UserService userService; @ApiOperation(value = "获取用户列表", notes = "获取所有用户列表") @GetMapping("/list") public List<User> list() { return userService.list(); } @ApiOperation(value = "添加用户", notes = "添加一个新用户") @PostMapping("/add") public String add(@ApiParam(name = "user", value = "用户信息", required = true) @RequestBody User user) { userService.add(user); return "success"; } @ApiOperation(value = "更新用户", notes = "根据用户ID更新用户信息") @PutMapping("/update/{id}") public String update(@ApiParam(name = "id", value = "用户ID", required = true) @PathVariable Long id, @ApiParam(name = "user", value = "用户信息", required = true) @RequestBody User user) { userService.update(id, user); return "success"; } @ApiOperation(value = "删除用户", notes = "根据用户ID删除用户") @DeleteMapping("/delete/{id}") public String delete(@ApiParam(name = "id", value = "用户ID", required = true) @PathVariable Long id) { userService.delete(id); return "success"; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值