SpringBoot中使用Knife4J的解决方案

目录
  • 一、引入依赖
  • 二、创建配置类
  • 三、常用注解
    • 3-1 @Api
      • 3-1-1 @Api 注解的常用属性,如下:
      • 3-1-2 @Api 注解的不常用属性,如下:
    • 3-2 @ApiOperation
      • 3-2-1 @ApiOperation 注解的常用属性,如下:
      • 3-2-2 @ApiOperation 注解的不常用属性,如下:
    • 3-3 @ApiImplicitParam
      • 3-3-1 @ApiImplicitParam 注解的常用属性,如下:
      • 3-3-2 @ApiImplicitParam 注解的不常用属性,如下:
    • 3-4 @ApiModel
      • 3-4-1 @ApiModel 注解的常用属性,如下:
    • 3-5 @ApiModelProperty
      • 3-5-1 @ApiModelProperty 注解的常用属性,如下:
      • 3-5-2 @ApiModelProperty 注解的不常用属性,如下:
    • 3-6 @ApiResponse
  • 四、配置JavaBean
  • 五、配置Controller
  • 六、接口文档预览

knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案。

knife4j的前身是swagger-bootstrap-ui,为了契合微服务的架构发展,由于原来swagger-bootstrap-ui采用的是后端Java代码+前端Ui混合打包的方式,在微服务架构下显的很臃肿,因此项目正式更名为knife4j。 knife4j官方网址:knife4j

一、引入依赖

Knife4J 官网:

https://doc.xiaominfo.com/

快速开始:https://doc.xiaominfo.com/docs/quick-start

<!--引入Knife4j的官方start包,Swagger2基于Springfox2.10.5项目-->
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <!--使用Swagger2-->
    <artifactId>knife4j-spring-boot-starter</artifactId>
    <version>2.0.9</version>
</dependency>

二、创建配置类

创建config包,在其中新建一个配置类:

@Configuration
@EnableSwagger2WebMvc
public class Knife4jConfiguration {

    @Bean(value = "dockerBean")
    public Docket dockerBean() {
        //指定使用Swagger2规范
        Docket docket=new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(new ApiInfoBuilder()
                //描述字段支持Markdown语法
                .description("# 写一个简要的描述")
                .termsOfServiceUrl("https://doc.xiaominfo.com/")
                .contact("可以写作者的信息")
                .version("1.0")
                .build())
                //分组名称
                .groupName("用户服务")
                .select()
                //这里指定Controller扫描包路径
                .apis(RequestHandlerSelectors.basePackage("com.xueou.boot.controller"))
                .paths(PathSelectors.any())
                .build();
        return docket;
    }
}
  • 最重要的配置还是:指定
  • Controller扫描包路径contact

官方是弃用了直接传字符串的这个设置方法,改用传入一个Contact类,看一下源码可以发现该类的结构(内容更丰富了:姓名、邮箱、URL连接)

三、常用注解

3-1 @Api

@Api 注解,添加在 Controller 类上,标记它作为 Swagger 文档资源。

3-1-1 @Api 注解的常用属性,如下:

  • tags 属性:用于控制 API 所属的标签列表。[] 数组,可以填写多个。
  • 可以在一个 Controller 上的 @Apitags 属性,设置多个标签,那么这个 Controller 下的 API 接口,就会出现在这两个标签中。
  • 如果在多个 Controller 上的 @Apitags 属性,设置一个标签,那么这些 Controller 下的 API 接口,仅会出现在这一个标签中。
  • 本质上,tags 就是为了分组 API 接口,和 Controller 本质上是一个目的。所以绝大数场景下,我们只会给一个 Controller 一个唯一的标签。

3-1-2 @Api 注解的不常用属性,如下:

  • produces 属性:请求请求头的可接受类型( Accept )。如果有多个,使用 , 分隔。
  • consumes 属性:请求请求头的提交内容类型( Content-Type )。如果有多个,使用 , 分隔。
  • protocols 属性:协议,可选值为 “http”、“https”、“ws”、“wss” 。如果有多个,使用 , 分隔。
  • authorizations 属性:授权相关的配置,[] 数组,使用 @Authorization 注解。hidden 属性:是否隐藏,不再 API 接口文档中显示。

@Api 注解的废弃属性,不建议使用,有 value、description、basePath、position 。

3-2 @ApiOperation

@ApiOperation 注解,添加在 Controller 方法上,标记它是一个 API 操作。

3-2-1 @ApiOperation 注解的常用属性,如下:

  • value 属性:API 操作名。
  • notes 属性:API 操作的描述。

3-2-2 @ApiOperation 注解的不常用属性,如下:

  • tags 属性:和 @API 注解的 tags 属性一致。
  • nickname 属性:API 操作接口的唯一标识,主要用于和第三方工具做对接。
  • httpMethod 属性:请求方法,可选值为 GET、HEAD、POST、PUT、DELETE、OPTIONS、PATCH 。因为 Swagger 会解析 SpringMVC 的注解,所以一般无需填写。
  • produces 属性:和 @API 注解的 produces 属性一致。
  • consumes 属性:和 @API 注解的 consumes 属性一致。
  • protocols 属性:和 @API 注解的 protocols 属性一致。
  • authorizations 属性:和 @API 注解的 authorizations 属性一致。
  • hidden 属性:和 @API 注解的 hidden 属性一致。
  • response 属性:响应结果类型。因为 Swagger 会解析方法的返回类型,所以一般无需填写。
  • responseContainer 属性:响应结果的容器,可选值为 List、Set、Map 。
  • responseReference 属性:指定对响应类型的引用。这个引用可以是本地,也可以是远程。并且,当设置了它时,会覆盖 response 属性。说人话,就是可以忽略这个属性,哈哈哈。responseHeaders 属性:响应头,[] 数组,使用 @ResponseHeader 注解。
  • code 属性:响应状态码,默认为 200 。
  • extensions 属性:拓展属性,[] 属性,使用 @Extension 注解。
  • ignoreJsonView 属性:在解析操作和类型,忽略 JsonView 注释。主要是为了向后兼容。

@ApiOperation 注解的废弃属性,不建议使用,有 position 。

3-3 @ApiImplicitParam

@ApiImplicitParam 注解,添加在 Controller 方法上,声明每个请求参数的信息。

3-3-1 @ApiImplicitParam 注解的常用属性,如下:

  • name 属性:参数名。
  • value 属性:参数的简要说明。
  • required 属性:是否为必传参数。默认为 false 。
  • dataType 属性:数据类型,通过字符串 String 定义。
  • dataTypeClass 属性:数据类型,通过 dataTypeClass 定义。在设置了dataTypeClass 属性的情况下,会覆盖 dataType 属性。推荐采用这个方式。
  • paramType 属性:参数所在位置的类型。有如下 5 种方式:

"path" 值:对应 SpringMVC 的 @PathVariable 注解。
【默认值】"query" 值:对应 SpringMVC 的 @PathVariable 注解。
"body" 值:对应 SpringMVC 的 @RequestBody 注解。
"header" 值:对应 SpringMVC 的 @RequestHeader 注解。
"form" 值:Form 表单提交,对应 SpringMVC 的 @PathVariable 注解。
绝大多数情况下,使用 “query” 值这个类型即可。

  • example 属性:参数值的简单示例。
  • examples 属性:参数值的复杂示例,使用 @Example 注解。

3-3-2 @ApiImplicitParam 注解的不常用属性,如下:

  • defaultValue 属性:默认值。
  • allowableValues 属性:允许的值。如果要设置多个值,有两种方式:

数组方式,即 {value1, value2, value3} 。例如说,{1, 2, 3} 。
范围方式,即 [value1, value2][value1, value2) 。例如说 [1, 5] 表示 1 到 5 的所有数字。如果有无穷的,可以使用 (-infinity, value2][value1, infinity)

  • allowEmptyValue 属性:是否允许空值。
  • allowMultiple 属性:是否允许通过多次传递该参数来接受多个值。默认为 false 。
  • type 属性:搞不懂具体用途,对应英文注释为 Adds the ability to override the detected type 。
  • readOnly 属性:是否只读。
  • format 属性:自定义的格式化。
  • collectionFormat 属性:针对 Collection 集合的,自定义的格式化。

当我们需要添加在方法上添加多个 @ApiImplicitParam 注解时,可以使用 @ApiImplicitParams 注解中添加多个。

3-4 @ApiModel

@ApiModel 注解,添加在 POJO 类,声明 POJO 类的信息。而在 Swagger 中,把这种 POJO 类称为 Model 类。所以,我们下文就统一这么称呼。

3-4-1 @ApiModel 注解的常用属性,如下:

  • value 属性:Model 名字。
  • description 属性:Model 描述。

3-4-2 @ApiModel 注解的不常用属性,如下:

  • parent 属性:指定该 Model 的父 Class 类,用于继承父 Class 的 Swagger 信息。
  • subTypes 属性:定义该 Model 类的子类 Class 们。
  • discriminator 属性:搞不懂具体用途,对应英文注释为 Supports model inheritance and polymorphism.
  • reference 属性:搞不懂具体用途,对应英文注释为 Specifies a reference to the corresponding type definition, overrides any other metadata specified

3-5 @ApiModelProperty

  • @ApiModelProperty 注解,添加在 Model 类的成员变量上,声明每个成员变量的信息。

3-5-1 @ApiModelProperty 注解的常用属性,如下:

  • value 属性:属性的描述。
  • dataType 属性:和 @ApiImplicitParam 注解的 dataType 属性一致。不过因为 @ApiModelProperty 是添加在成员变量上,可以自动获得成员变量的类型。
  • required 属性:和 @ApiImplicitParam 注解的 required 属性一致。
  • example 属性:@ApiImplicitParam 注解的 example 属性一致。

3-5-2 @ApiModelProperty 注解的不常用属性,如下:

  • name 属性:覆盖成员变量的名字,使用该属性进行自定义。
  • allowableValues 属性:和 @ApiImplicitParam 注解的 allowableValues 属性一致。
  • position 属性:成员变量排序位置,默认为 0 。
  • hidden 属性:@ApiImplicitParam 注解的 hidden 属性一致。
  • accessMode 属性:访问模式,有 AccessMode.AUTO、AccessMode.READ_ONLY、AccessMode.READ_WRITE 三种,默认为 AccessMode.AUTO 。
  • reference 属性:和 @ApiModel 注解的 reference 属性一致。
  • allowEmptyValue 属性:和 @ApiImplicitParam 注解的 allowEmptyValue 属性一致。
  • extensions 属性:和 @ApiImplicitParam 注解的 extensions 属性一致。

@ApiModelProperty 注解的废弃属性,不建议使用,有 readOnly 。

3-6 @ApiResponse

在大多数情况下,我们并不需要使用 @ApiResponse 注解,因为我们会类似 UserController#get(id) 方法这个接口,返回一个 Model 即可。

  • @ApiResponse 注解,添加在 Controller 类的方法上,声明每个响应参数的信息。
  • @ApiResponse 注解的属性,基本已经被 @ApiOperation 注解所覆盖,如下:
  • message 属性:响应的提示内容。
  • code 属性:和 @ApiOperation 注解的 code 属性一致。
  • response 属性:和 @ApiOperation 注解的 response 属性一致。
  • reference 属性:和 @ApiOperation 注解的 responseReference 属性一致。
  • responseHeaders 属性:和 @ApiOperation 注解的 responseHeaders 属性一致。
  • responseContainer 属性:和 @ApiOperation 注解的 responseContainer 属性一致。
  • examples 属性:和 @ApiOperation 注解的 examples 属性一致。

当我们需要添加在方法上添加多个 @ApiResponse 注解时,可以使用 @ApiResponses 注解中添加多个。

四、配置JavaBean

主要用于返回参数、或是接收参数的时候进行说明。

@Getter
@Setter
@ToString
@NoArgsConstructor
@ApiModel(value = "轮播图对象", description = "")
public class Banner implements Serializable {
    @ApiModelProperty(value = "id", example = "1")
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;
    @ApiModelProperty(value = "图像链接", example = "https://xxx/xxx.png")
    private String imgUrl;
    @ApiModelProperty(value = "标题", example = "这是一个标题哟~")
    private String title;
}

我自己用的时候,又封装了一层,设置了几个JavaBean用于包装返回的响应结果:

分别用于返回单个数据、数据列表,同时附带上状态码和说明信息。

@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
public abstract class RBean {
    @ApiModelProperty(value = "响应码",
            position = 0,
            example = "200",
            notes = "200: 成功;500:失败;")
    private Integer code;
    @ApiModelProperty(value = "响应说明", position = 1, example = "xx数据获取成功。")
    private String msg;
}

// =====================
@EqualsAndHashCode(callSuper=true)
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
public class ROneBean<T> extends RBean {

    @ApiModelProperty(value = "数据项", position = 2)
    private T data;
}

// =======================
@EqualsAndHashCode(callSuper=true)
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
public class RListBean<T> extends RBean{
    @ApiModelProperty(value = "数据列表", position = 2)
    private List<T> data;
}

五、配置Controller

潦草的写几个接口

@Api(tags = "首页模块")
@RestController
public class IndexController {
    @Resource
    IBannerService iBannerService;

    @ApiOperation(value = "域名直接转接口文档", hidden = true)
    @GetMapping("/")
    public void toDoc(HttpServletResponse response) throws IOException {
        response.sendRedirect("/doc.html");
    }

    @ApiOperation("新增轮播图数据")
    @PostMapping("/addBanners")
    public void putBanner(@RequestBody Banner banner){
		// ......
    }

    @ApiOperation("查询一个具体轮播图")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "title",value = "标题",required = true,example = "小白菜"),
            @ApiImplicitParam(name = "date",value = "时间",required = true,example = "2022")
    })
    @GetMapping("/searchOneBanner")
    public ROneBean<Banner> searchOneBanner(@RequestParam(name = "title",defaultValue = "") String name,
                                           @RequestParam(name = "date", defaultValue = "") String address){
        ROneBean<Banner> resp = new ROneBean<>();
        // ...
        return null
    }

    @ApiOperation("获取轮播图数据")
    @GetMapping("/getBanners")
    public RListBean<Banner> getBanners(){
        RListBean<Banner> resp = new RListBean<>();
        List<Banner> banners = iBannerService.list();
        if(banners.isEmpty()){
            resp.setCode(200);
            resp.setMsg("轮播图数据为空。");
        }else{
            resp.setCode(200);
            resp.setMsg("获取轮播图数据成功");
            resp.setData(banners);
        }
        return resp;
    }
}

六、接口文档预览

到此这篇关于SpringBoot中使用Knife4J的文章就介绍到这了,更多相关SpringBoot 使用Knife4J内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Springboot整合knife4j与shiro的操作

    一.介绍knife4j 增强版本的Swagger 前端UI,取名knife4j是希望她能像一把匕首一样小巧,轻量,并且功能强悍,更名也是希望把她做成一个为Swagger接口文档服务的通用性解决方案,不仅仅只是专注于前端Ui前端. 二.Spring Boot 整合knife4j 第一步 在Maven中的pom.xml文件引入: <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>kni

  • Springboot中整合knife4j接口文档的过程详解

    目录 什么是knife4j 界面欣赏 主页 接口文档 调试界面 参数实体 整合 knife4j 引入 maven 依赖 knife4j 配置文件 配置API接口 knife4j 常用特性 全局参数 离线文档 在项目开发过程中,web项目的前后端分离开发,APP开发,需要由前端后端工程师共同定义接口,编写接口文档,之后大家都根据这个接口文档进行开发. 什么是knife4j 简单说knife4j就swagger的升级版API文档的一个框架,但是用起来比swagger方便多了,UI更加丰富. 界面欣赏

  • 关于springboot集成swagger及knife4j的增强问题

    参考链接:狂神的Swagger笔记 号称世界上最流行的API框架 Restful Api 文档在线自动生成器 => API 文档 与API 定义同步更新 直接运行,在线测试API 支持多种语言 (如:Java,PHP等) 官网:swagger SpringBoot集成Swagger 添加maven依赖 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2&

  • Springboot2整合knife4j过程解析

    knife4j官网:https://doc.xiaominfo.com/guide/useful.html 这玩艺就swagger的升级版,但是用起来比swagger方便多了,至少不会出现莫名的版本兼容问题 下面记录一个配置示例 1.代码结构 2.pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0&

  • springboot集成swagger3与knife4j的详细代码

    目录 springboot集成swagger3 swagger3的springboot启动器jar包 编写TestController代码 创建Swagger3Configuration 运行演示 对接口进行注解 swagger中常用的注解 接口基本使用 运行结果 集成更好的UI-knife4j maven 启动器 springboot集成swagger3 swagger3的springboot启动器jar包 <!-- https://mvnrepository.com/artifact/io.

  • SpringBoot中整合knife4j接口文档的实践

    在项目开发中,web项目的前后端分离开发,APP开发,需要由前后端工程师共同定义接口,编写接口文档,之后大家都根据这个接口文档进行开发,到项目结束前都要一直维护 接口文档使得项目开发过程中前后端工程师有一个统一的文件进行沟通交流开发,项目维护中或者项目人员更迭,方便后期人员查看.维护 一.界面先赏 1.首页 2.接口文档 3.调试 二.整合 knife4j 1.引入 maven 依赖 <!-- knife4j接口文档 start --> <dependency> <group

  • SpringBoot中使用Knife4J的解决方案

    目录 一.引入依赖 二.创建配置类 三.常用注解 3-1 @Api 3-1-1 @Api 注解的常用属性,如下: 3-1-2 @Api 注解的不常用属性,如下: 3-2 @ApiOperation 3-2-1 @ApiOperation 注解的常用属性,如下: 3-2-2 @ApiOperation 注解的不常用属性,如下: 3-3 @ApiImplicitParam 3-3-1 @ApiImplicitParam 注解的常用属性,如下: 3-3-2 @ApiImplicitParam 注解的不

  • 解决springboot中@DynamicUpdate注解无效的问题

    springboot 中 @DynamicUpdate 注解无效解决方案 遇到的问题 项目中使用 jpa,以前没用过,所以踩坑在所难免. 在使用过程中,要更新一条记录的某个字段,更新成功以后,发现整条记录只剩下我更新的那个字段,其他的全部为空了. 瞬间明白,这种更新是全覆盖,针对每个字段 update,实体类没赋值的字段,也直接将空值 set 过去了. 寻求解决方案 正在庆幸这么容易就解决,突然发现并没有这么简单. 群众的力量是无穷大的,我立刻就明白这个注解为什么无效,原来是搞错了它的用途. 一

  • 详解springboot中redis的使用和分布式session共享问题

    对于分布式使用Nginx+Tomcat实现负载均衡,最常用的均衡算法有IP_Hash.轮训.根据权重.随机等.不管对于哪一种负载均衡算法,由于Nginx对不同的请求分发到某一个Tomcat,Tomcat在运行的时候分别是不同的容器里,因此会出现session不同步或者丢失的问题. 实际上实现Session共享的方案很多,其中一种常用的就是使用Tomcat.Jetty等服务器提供的Session共享功能,将Session的内容统一存储在一个数据库(如MySQL)或缓存(如Redis)中. 本文旨在

  • springboot中如何通过cors协议解决跨域问题

    1.对于前后端分离的项目来说,如果前端项目与后端项目部署在两个不同的域下,那么势必会引起跨域问题的出现. 针对跨域问题,我们可能第一个想到的解决方案就是jsonp,并且以前处理跨域问题我基本也是这么处理. 但是jsonp方式也同样有不足,不管是对于前端还是后端来说,写法与我们平常的ajax写法不同,同样后端也需要作出相应的更改.并且,jsonp方式只能通过get请求方式来传递参数,当然也还有其它的不足之处,针对于此,我并没有急着使用jsonp的方式来解决跨域问题,去网上找寻其它方式,也就是本文主

  • mybatis逆向工程与分页在springboot中的应用及遇到坑

    最近在项目中应用到springboot与mybatis,在进行整合过程中遇到一些坑,在此将其整理出来,便于以后查阅与复习. 项目运行环境为:eclispe+jdk1.8+maven 搭建Spring Boot环境 首先建立maven project,在生成的pom文件中加入依赖,代码如下: <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-

  • spring-boot 多线程并发定时任务的解决方案

    刚刚看了下Spring Boot实现定时任务的文章,感觉还不错.Spring Boot 使用Spring自带的Schedule来实现定时任务变得非常简单和方便.在这里个大家分享下. 开启缓存注解 @SpringBootApplication @EnableScheduling //开启定时任务 public class Application { public static void main(String[] args) { SpringApplication.run(Application.

  • 在springboot中实现个别bean懒加载的操作

    懒加载---就是我们在spring容器启动的是先不把所有的bean都加载到spring的容器中去,而是在当需要用的时候,才把这个对象实例化到容器中. @Lazy 在需要懒加载的bean上加上@Lazy就可以了 补充知识:springboot组件懒加载的坑及加载规则 什么是懒加载? 懒加载的意思是不在项目启动的时候实例出来这个组件 @RestController public class ApiController { @Autowired Skill kobSkillImpl; @Request

  • SpringBoot集成vue的开发解决方案

    最近由于工作要求:前端采用vue开发,后端采用springboot开发,前后端分离开发,最后前端页面又整合到后端来.经历多次采坑,总结以下方案: vue build后的文件部署到springboot目录 vue打包后,会生成dist目录 springboot静态资源目录如下: SpringBoot处理静态资源和页面,设置如下: @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registr

随机推荐