当前位置:   article > 正文

SpringBoot 整合 Swagger3_spring boot3的swagger

spring boot3的swagger

目录

一 为什么需要 swagger

二 swagger 是什么

三 swagger 集成

3.1 引入依赖

3.2 swagger 配置

3.3 Restful 接口

3.4 Swagger3 文档

四 swagger 注解说明


一 为什么需要 swagger

        目前前后端分离是一个业内趋势,那前后端接口协议,可以记录在 wiki 或者 gitlab 上, 但是记录在 wiki 或者 gitlab 那块手写接口文档很容易出现如下情况:

       1 需求的不断叠加,后端需要定期的更新文档,更新完了之后需要同步给客户端或者前端很费劲

       2 不能直接测试接口,通常需要使用工具,比如 postman;或者通过 curl 命令,门槛较高,麻烦。

       3 如果一个项目中的接口太多,维护都是一个成本很高的问题。

       swagger 就能完美的解决上述三个问题,但是 Swagger 的代码侵入性太强。

       为了解决上述问题,swagger 出现了。

二 swagger 是什么

       swagger 是一个自动生成接口文档的工具。

       1 服务启动,自动更新文档。

       2 服务启动,能在线测试接口。

       3 不需要维护接口 wiki 或者接口的 gitlab 。

三 swagger 集成

       swagger 已经发布到了新版的 swagger3 ,且相比 swagger2 配置更少,使用更简洁。

3.1 引入依赖

  1. <!--swagger-->
  2. <dependency>
  3. <groupId>io.springfox</groupId>
  4. <artifactId>springfox-boot-starter</artifactId>
  5. <version>3.0.0</version>
  6. </dependency>

3.2 swagger 配置

生成 swagger 配置类

  1. package com.sb.config;
  2. import io.swagger.annotations.ApiOperation;
  3. import org.springframework.context.annotation.Bean;
  4. import org.springframework.context.annotation.Configuration;
  5. import springfox.documentation.builders.ApiInfoBuilder;
  6. import springfox.documentation.builders.PathSelectors;
  7. import springfox.documentation.builders.RequestHandlerSelectors;
  8. import springfox.documentation.service.ApiInfo;
  9. import springfox.documentation.service.Contact;
  10. import springfox.documentation.spi.DocumentationType;
  11. import springfox.documentation.spring.web.plugins.Docket;
  12. @Configuration
  13. public class Swagger3Config {
  14. @Bean
  15. public Docket createRestApi() {
  16. return new Docket(DocumentationType.OAS_30)
  17. .apiInfo(apiInfo())
  18. .select()
  19. .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
  20. .paths(PathSelectors.any())
  21. .build();
  22. }
  23. private ApiInfo apiInfo() {
  24. return new ApiInfoBuilder()
  25. .title("springboot整合swagger构建api文档")
  26. .description("更多问题请关注'新猿一马'公众号")
  27. .contact(new Contact("新猿一马","https://blog.csdn.net/jack1liu","15810361169@163.com"))
  28. .version("1.0")
  29. .build();
  30. }
  31. }

启动类添加 @EnableOpenApi 启动 Swagger。

  1. package com.sb;
  2. import org.mybatis.spring.annotation.MapperScan;
  3. import org.springframework.boot.SpringApplication;
  4. import org.springframework.boot.autoconfigure.SpringBootApplication;
  5. import springfox.documentation.swagger2.annotations.EnableSwagger2;
  6. @MapperScan(basePackages = "com.sb.dao")
  7. @SpringBootApplication
  8. @EnableSwagger2
  9. public class SpringbootSwaggerApplication {
  10. public static void main(String[] args) {
  11. SpringApplication.run(SpringbootSwaggerApplication.class, args);
  12. }
  13. }

3.3 Restful 接口

  1. package com.sb.controller;
  2. import com.sb.domain.User;
  3. import com.sb.dto.RetDTO;
  4. import com.sb.service.UserService;
  5. import io.swagger.annotations.ApiImplicitParam;
  6. import io.swagger.annotations.ApiImplicitParams;
  7. import io.swagger.annotations.ApiOperation;
  8. import org.springframework.web.bind.annotation.*;
  9. import javax.annotation.Resource;
  10. import java.util.List;
  11. @RestController
  12. @RequestMapping(value="/users")
  13. public class UserController {
  14. @Resource
  15. private UserService userService;
  16. @ApiOperation(value="获取用户列表", notes="")
  17. @RequestMapping(value={"/list"}, method=RequestMethod.GET)
  18. public RetDTO<List<User>> getUserList() {
  19. List<User> r = userService.getUserList();
  20. return RetDTO.getReturnJson(r);
  21. }
  22. @ApiOperation(value="创建用户", notes="根据User对象创建用户")
  23. @ApiImplicitParam(name = "user", value = "用户详细实体user", required = true, dataType = "User")
  24. @RequestMapping(value="/insert", method=RequestMethod.POST)
  25. public RetDTO insert(@RequestBody User user) {
  26. return RetDTO.getReturnJson(userService.add(user));
  27. }
  28. @ApiOperation(value="获取用户详细信息", notes="根据url的id来获取用户详细信息")
  29. @ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Long")
  30. @RequestMapping(value="/{id}", method=RequestMethod.GET)
  31. public RetDTO<User> getUser(@PathVariable Long id) {
  32. return RetDTO.getReturnJson(userService.getUserById(id));
  33. }
  34. @ApiOperation(value="更新用户详细信息", notes="根据url的id来指定更新对象,并根据传过来的user信息来更新用户详细信息")
  35. @ApiImplicitParams({
  36. @ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Long"),
  37. @ApiImplicitParam(name = "user", value = "用户详细实体user", required = true, dataType = "User")
  38. })
  39. @RequestMapping(value="/{id}", method=RequestMethod.PUT)
  40. public RetDTO putUser(@PathVariable Long id, @RequestBody User user) {
  41. return RetDTO.getReturnJson(userService.update(id, user));
  42. }
  43. @ApiOperation(value="删除用户", notes="根据url的id来指定删除对象")
  44. @ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Long")
  45. @RequestMapping(value="/{id}", method=RequestMethod.DELETE)
  46. public RetDTO deleteUser(@PathVariable Long id) {
  47. return RetDTO.getReturnJson(userService.delete(id));
  48. }
  49. }

3.4 Swagger3 文档

启动 SpringBoot 项目,访问 http://localhost:8080/swagger-ui/index.html

四 swagger 注解说明

    swagger通过注解表明该接口会生成文档,包括接口名、请求方法、参数、返回信息的等等。

  • @Api:修饰整个类,描述Controller的作用
  • @ApiOperation:描述一个类的一个方法,或者说一个接口
  • @ApiParam:单个参数描述
  • @ApiModel:用对象来接收参数
  • @ApiProperty:用对象接收参数时,描述对象的一个字段
  • @ApiResponse:HTTP响应其中1个描述
  • @ApiResponses:HTTP响应整体描述
  • @ApiIgnore:使用该注解忽略这个API
  • @ApiError :发生错误返回的信息
  • @ApiImplicitParam:一个请求参数
  • @ApiImplicitParams:多个请求参数

微信公众号:「新猿一马」,微信扫一扫。

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/939911
推荐阅读
相关标签
  

闽ICP备14008679号