当前位置:   article > 正文

SpringBoot整合Swagger最新ui界面(knife4j)_swagger最新依赖

swagger最新依赖

 

Swagger官网地址:https://swagger.io/

Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。功能主要包含以下几点:

  • 使得前后端分离开发更加方便,有利于团队协作。
  • 接口文档在线自动生成,降低后端开发人员编写接口文档的负担。
  • 接口功能测试。

使用Swagger只需要按照它的规范去定义接口及接口相关的信息,再通过Swagger衍生出来的一系列项目和工具,就可以做到生成各种格式的接口文档,以及在线接口调试页面等等。

Knife4j(小刀 four java,log4j哈哈)

如果直接使用Swagger,需要按照Swagger的规范定义接口,实际上就是编写Json文件,编写起来比较繁琐、并不方便。

而在项目中使用,我们一般会选择一些现成的框架来简化文档的编写,而这些框架是基于Swagger的(例如 knife4j)。

Knife4j是一款基于Swagger的增强工具,官网地址:https://doc.xiaominfo.com/

 

使用knife4j只需在pom.xml中引入如下依赖即可:

  1. <dependency>
  2. <groupId>com.github.xiaoymin</groupId>
  3. <artifactId>knife4j-spring-boot-starter</artifactId>
  4. <version>3.0.2</version>
  5. </dependency>

1. 使用方式

1、导入knife4j起步依赖:

  1. <dependency>
  2.     <groupId>com.github.xiaoymin</groupId>
  3.     <artifactId>knife4j-spring-boot-starter</artifactId>
  4.     <version>3.0.2</version>
  5. </dependency>


2、编写Swagger配置类:

  1. package com.baidou.config;
  2. import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
  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. import springfox.documentation.swagger2.annotations.EnableSwagger2;
  13. /**
  14.  * Swagger2配置类(生成接口文档)
  15.  *
  16.  * @author 白豆五
  17.  * @version 2023/1/21
  18.  * @since JDK8
  19.  */
  20. @Configuration
  21. @EnableSwagger2 //开启swagger2注解支持
  22. @EnableKnife4j  //开启Knife4j注解支持
  23. public class SwaggerConfig {
  24.     @Bean
  25.     public Docket webApiConfig() { //生成接口文档的清单
  26.         // 文档类型
  27.         return new Docket(DocumentationType.SWAGGER_2)
  28.                 .groupName("webApi")
  29.                 .apiInfo(webApiInfo())
  30.                 .select()
  31.                 //指定controller包扫描路径
  32.                 .apis(RequestHandlerSelectors.basePackage("com.baidou.controller"))
  33.                 .paths(PathSelectors.any())
  34.                 .build();
  35.     }
  36.     //配置api信息
  37.     private ApiInfo webApiInfo() {
  38.         return new ApiInfoBuilder()
  39.                 .title("网站-API文档")
  40.                 .description("本文档描述了xxx管理系统微服务接口定义")
  41.                 .version("1.0")
  42.                 .contact(new Contact("白豆五", "https://blog.csdn.net/qq_46921028", "13212341234@163.com"))
  43.                 .build();
  44.     }
  45. }


注意: Docket声明时,有一个包扫描的路径,该路径指定的是Controller所在包的路径。因为Swagger在生成接口文档时,就是根据这里指定的包路径,自动的扫描该包下的@Controller, @RestController, @RequestMapping等SpringMVC的注解,依据这些注解来生成对应的接口文档。


3、 设置静态资源映射(对Swagger的静态资源放行)

由于Swagger生成的在线文档中,涉及到很多静态资源,这些静态资源需要添加静态资源映射,否则接口文档页面无法访问。

  1. @Configuration
  2. public class WebMvcConfig implements WebMvcConfigurer {
  3.     // 静态资源放行
  4.     @Override
  5.     public void addResourceHandlers(ResourceHandlerRegistry registry) {
  6.         registry.addResourceHandler("/web/**").addResourceLocations("classpath:/web/");
  7.         
  8.         // 对swaggger静态资源放行
  9.         registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/");
  10.         registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
  11.         
  12.     }
  13. }


如果配置拦截器,需要对以下资源放行:

  1. "/doc.html",
  2. "/webjars/**",
  3. "/swagger-resources",
  4. "/v2/api-docs"

4、访问swagger:http://localhost:8081/doc.html

 

 


2. 常用注解


Swagger提供了很多的注解,通过这些注解,我们可以更好更清晰的描述我们的接口,包含接口的请求参数、响应数据、数据模型等。核心的注解,主要包含以下几个:

注解位置说明
@Api添加到Controller类上,表示对类的说明
@ApiModel类(通常是实体类)描述实体类的作用
@ApiModelProperty属性描述实体类的属性
@ApiOperation方法说明方法的用途、作用
@ApiImplicitParams方法表示一组参数说明
@ApiImplicitParam方法用在@ApiImplicitParams注解中,指定一个请求参数的各个方面的属性
@ApiParam方法形参上描述接口方法的形参

示例:注解的使用

在实体类中使用:

  1. @Data
  2. @AllArgsConstructor
  3. @NoArgsConstructor
  4. @ApiModel("学生实体类")
  5. public class Stu implements Serializable {
  6.     private static final long serialVersionUID = 1L;
  7.     @ApiModelProperty("主键")
  8.     private Long id;
  9.     @ApiModelProperty("姓名")
  10.     private String name;
  11.     @ApiModelProperty("密码")
  12.     private String password;
  13.     @ApiModelProperty("年龄")
  14.     private Integer age;
  15.     @ApiModelProperty("电话")
  16.     private String tel;
  17. }


在Controller类中使用:
 

  1. @RestController
  2. @RequestMapping("/stu")
  3. @Api(tags = "学生相关接口")
  4. public class StuController {
  5.     @Autowired
  6.     StuMapper stuMapper;
  7.     @GetMapping("/list")
  8.     @ApiOperation(value = "获取学生列表接口")
  9.     public String findList() {
  10.         List<Stu> list = stuMapper.selectAll();
  11.         return JSON.toJSONString(list);
  12.     }
  13.     @GetMapping()
  14.     @ApiOperation(value = "通过名字获取学生列表接口")
  15.     // required = true 表示必须传递参数
  16.     public String select( @ApiParam(value = "学生姓名",required = true) @RequestParam String name) {
  17.         List<Stu> list = stuMapper.select(name);
  18.         return JSON.toJSONString(list);
  19.     }
  20.     @DeleteMapping("/{id}")
  21.     @ApiOperation(value = "通过id删除学生信息")
  22.     @ApiImplicitParams({
  23.             @ApiImplicitParam(name = "id",value = "学生的id",required = true),
  24.     })
  25.     public String delete(@PathVariable Long id) {
  26.         int row = stuMapper.deleteStu(id);
  27.         return row == 1 ? "ok" : "error";
  28.     }
  29.     @PostMapping("/save")
  30.     @ApiOperation(value = "新增学生信息")
  31.     public String save(@ApiParam("学生信息") @RequestBody Stu stu) {
  32.         int row = stuMapper.save(stu);
  33.         return row == 1 ? "ok" : "error";
  34.     }
  35.     @PutMapping("/update")
  36.     @ApiOperation(value = "修改学生信息")
  37.     public String update(@ApiParam("学生信息")@RequestBody Stu stu) {
  38.         int row = stuMapper.update(stu);
  39.         return row == 1 ? "ok" : "error";
  40.     }
  41. }

 只需使用Swagger提供的注解便可生成接口文档。
 

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

闽ICP备14008679号