Swagger3.X 接口文档 (二)

本文介绍了Swagger3.x中ApiModel和ApiModelProperty对象注解的使用,展示了如何为API接口创建详细的说明,包括字段说明、数据类型、必填项等。同时,讲解了如何使用@ApiResponse描述接口响应,并提供了实际的接口测试示例。此外,还提到了Swagger3.x在项目整合中的注意事项,如接口文档的HTTP请求方式、线上环境的禁用以及团队使用考虑。
摘要由CSDN通过智能技术生成

一、Swagger3.x对象注解ApiModel讲解

APiModel和ApiModelProperty对象注解介绍

@ApiModel()

用于类表示对类进行说明,用于参数用实体类接收,value–表示对象名,description–描述

这种一般用在post创建的时候,使用对象提交这样的场景

@ApiModelProperty()

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

value–字段说明

name–重写属性名字

dataType–重写属性类型

required–是否必填

example–举例说明

hidden–隐藏

@ApiModel(value = "新增用户请求模型")
@Data  //lombok(必须要写)
public class SaveUserRequest {

    @ApiModelProperty(value = "主键id")
    private int id;

    @ApiModelProperty(value = "名称" ,required = true,example = "mike")
    private  String name;

    @ApiModelProperty(value = "邮箱" ,required = true,example = "126.com")
    private String email;

    private String phone;

}

新增用户对象接口测试

    @ApiOperation("新增用户")
    @PostMapping("save")
    public JsonData  save(SaveUserRequest saveUserRequest) {  //参数SaveUserRequest
        //返回数据
        return JsonData.buildSuccess();
    }

import org.springframework.web.bind.annotation.*;
   @ApiOperation("新增用户")
    @PostMapping("save")
    public JsonData  save(@RequestBody SaveUserRequest saveUserRequest) {  //参数SaveUserRequest
        //返回数据
        return JsonData.buildSuccess();
    }

 

 

二、Swagger3.x响应结果ApiResponse和测试面板

@ApiResponse 描述接口响应

http://localhost:8081/swagger-ui/index.html/

import io.swagger.v3.oas.annotations.responses.ApiResponse;
import io.swagger.v3.oas.annotations.responses.ApiResponses;

@ApiOperation("用户登录")
@PostMapping("login")
@ApiResponses({
       @ApiResponse(responseCode = "302",description = "重定向"),
       @ApiResponse(responseCode = "403",description = "没权限"),
})
public JsonData login(
        @ApiParam(name = "name", value = "用户名", example = "mike") @RequestParam("name") String name,
        @ApiParam(name = "phone", value = "手机号", example = "110") @RequestParam("phone") String phone
        ) {
    //返回数据
    return JsonData.buildSuccess();
}

 使用常量

 

测试面板

Try it out|Execute|Response body

 

三、Swagger3.x和项目整合的注意事项

1)明确接口的Http请求方式:一个接口使用@RequestMapping会生成多个文档

2)线上不要开启接口文档 (修改:swagger.enable=false)

3)考虑团队当下和未来是否可以一直用,没有说百分百好用,缺点和优点都要知道。

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值