SpringBoot整合Swagger3生成接口文档过程解析

网友投稿 676 2022-11-30


SpringBoot整合Swagger3生成接口文档过程解析

前后端分离的项目,接口文档的存在十分重要。与手动编写接口文档不同,swagger是一个自动生成接口文档的工具,在需求不断变更的环境下,手动编写文档的效率实在太低。与新版的swagger3相比swagger2配置更少,使用更加方便。

一、pom文件中引入Swagger3依赖

io.springfox

springfox-boot-starter

3.0.0

二、Application上面加入@EnableOpenApi注解

@EnableOpenApi

@SpringBootApplication

@MapperScan(basePackages = {"cn.ruiyeclub.dao"})

public class Swagger3Application {

public static void main(String[] args) {

SpringApplication.run(Swagger3Application.class, args);

}

}

三、Swagger3Config的配置

@Configuration

public class Swagger3Config {

@Bean

publicuQAFZ Docket createRestApi() {

return new Docket(DocumentationType.OAS_30)

.apiInfo(apiInfo())

.select()

.apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))

.paths(PathSelectors.any())

.build();

}

private ApiInfo apiInfo() {

return new ApiInfoBuilder()

.title("Swagger3接口文档")

.description("更多请咨询服务开发者Ray。")

.contact(new Contact("Ray。", "http://ruiyeclub.cn", "ruiyeclub@foxmail.com"))

.version("1.0")

.build();

}

}

四、Swagger注解的使用说明

@Api:用在请求的类上,表示对类的说明

tags="说明该类的作用,可以在UI界面上看到的注解"

http://value="该参数没什么意义,在UI界面上也看到,所以不需要配置"

@ApiOperation:用在请求的方法上,说明方法的用途、作用

value="说明方法的用途、作用"

notes="方法的备注说明"

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

@ApiImplicitParam:用在@ApiImplicitParams注解中,指定一个请求参数的各个方面

name:参数名

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

required:参数是否必须传

paramType:参数放在哪个地方

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

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

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

body(不常用)

form(不常用)

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

defaultValue:参数的默认值

@ApiResponses:用在请求的方法上,表示一组响应

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

code:数字,例如400

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

response:抛出异常的类

@ApiModel:用于响应类上,表示一个返回响应数据的信息

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

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

@ApiModelProperty:用在属性上,描述响应类的属性

Controller层的配置:

@Api(tags = "用户信息管理")

@RestController

@RequestMapping("userRecord")

public class UserRecordController extends ApiController {

/**

* 服务对象

*/

@Resource

private UserRecordService userRecordService;

/**

* 分页查询所有数据

* @param page 分页对象

* @param userRecord 查询实体

* @return 所有数据

*/

@ApiOperation("分页查询所有数据")

@GetMapping("page")

public R selectAll(Page page, UserRecord userRecord) {

return success(this.userRecordService.page(page, new QueryWrapper<>(userRecord)));

}

/**

* 通过主键查询单条数据

* @param id 主键

* @return 单条数据

*/

@ApiOperation("通过主键查询单条数据")

@GetMapping("{id}")

public R selectOne(@PathVariable Serializable id) {

return success(this.userRecordService.getById(id));

}

/**

* 新增数据

* @param userRecord 实体对象

* @return 新增结果

*/

@ApiOperation("新增数据")

@PostMapping("insert")

public R insert(@RequestBody UserRecord userRecord) {

return success(this.userRecordService.save(userRecord));

}

/**

* 修改数据

* @param userRecord 实体对象

* @return 修改结果

*/

@ApiOperation("修改数据")

@PutMapping("update")

public R update(@RequestBody UserRecord userRecord) {

return success(this.userRecordService.updateById(userRecord));

}

/**

* 删除数据

* @param idList 主键结合

* @return 删除结果

*/

@ApiOperation("删除数据")

@DeleteMapping("delete")

public R delete(@RequestParam("idList") List idList) {

return success(this.userRecordService.removeByIds(idList));

}

}

五、Swagger界面效果

Swagger的访问路径由port/swagger-ui.html改成了port/swagger-ui/ 或port/swagger-ui/index.htmluQAFZ,项目演示代码在springboot-swagger


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java多线程三种主要实现方式解析
下一篇:详解Mybatis框架SQL防注入指南
相关文章

 发表评论

暂时没有评论,来抢沙发吧~