Knife4j是一個集Swagger2 和 OpenAPI3 為一體的增強解決方案
Knife4j 是為 Java MVC 框架整合 Swagger 生成 Api 檔案的增強解決方案,前身是 swagger-bootstrap-ui
,致力於 springfox-swagger
的增強 UI 實現。knife4j 為了契合微服務的架構發展,由於原來 swagger-bootstrap-ui
採用的是後端 Java 程式碼 + 前端 UI 混合打包的方式,在微服務架構下顯的很臃腫,因此專案正式更名為 knife4j,更名後主要專注的方面如下:
版本 | 說明 |
---|---|
1.0~1.9.6 | 名稱是叫swagger-bootstrap-ui ,藍色風格Ui |
1.9.6 | 藍色面板風格,開始更名,增加更多後端模組 |
2.0~2.0.5 | Ui基於Vue2.0+AntdV重寫,黑色風格,參考範例,底層依賴的springfox框架版本是2.9.2,僅提供Swagger2規範的適配 |
2.0.6~2.0.9 | 底層springfox框架版本升級知2.10.5,,僅提供Swagger2規範的適配 |
3.0~3.0.3 | 底層依賴springfox框架版本升級至3.0.3,OpenAPI規範是v3,過度版本,建議開發者不要使用 |
4.0~ | 區分OpenAPI2和Swagger3的Maven座標artifactId OpenAPI2規範伺服器端解析框架穩定在springfox2.10.5 OpenAPI3框架伺服器端解析跟隨springdoc專案更新迭代 建議開發者使用該版本,請參考4.x升級檔案 |
Spring Boot版本相容性
Spring Boot版本 | Knife4j Swagger2規範 | Knife4j OpenAPI3規範 |
---|---|---|
1.5.x~2.0.0 | <Knife4j 2.0.0 | >=Knife4j 4.0.0 |
2.0~2.2 | Knife4j 2.0.0 ~ 2.0.6 | >=Knife4j 4.0.0 |
2.2.x~2.4.0 | Knife4j 2.0.6 ~ 2.0.9 | >=Knife4j 4.0.0 |
2.4.0~2.7.x | >=Knife4j 4.0.0 | >=Knife4j 4.0.0 |
>= 3.0 | >=Knife4j 4.0.0 | >=Knife4j 4.0.0 |
nife4j版本 | Swagger2規範 | OpenAPI3規範 | 說明 |
---|---|---|---|
1.0~1.9.6 | springfox 2.9.2 | 無 | Knife4j的前身,名稱為swagger-bootstrap-ui |
1.9.6~2.0.5 | springfox 2.9.2 | 無 | |
2.0.6~2.0.9 | springfox 2.10.5 | 無 | |
3.0.0~3.0.3 | springfox 3.0.3 | 無 | 過度版本,建議開發者不要使用 |
4.0.0~ | springfox 2.10.5 | >=springdoc-openapi 1.6.9 | Swagger2規範穩定使用springfox2.10.5保持不變。開發者應該儘早遷移到OpenAPI3規範上來,請參考4.x升級檔案 |
1.引入依賴
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
<version>4.3.0</version>
</dependency>
2.編寫設定類
package com.mcode.knife4jdemo.config;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springdoc.core.models.GroupedOpenApi;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* ClassName: Knife4jConfig
* Package: com.mcode.knife4jdemo.config
* Description:
*
* @Author: robin
* @Version: v1.0
*/
@Configuration
public class Knife4jConfig {
@Bean
public GroupedOpenApi adminApi() { // 建立了一個api介面的分組
return GroupedOpenApi.builder()
.group("admin-api") // 分組名稱
.pathsToMatch("/admin/**") // 介面請求路徑規則
.build();
}
@Bean
public OpenAPI openAPI(){
return new OpenAPI()
.info(new Info()
.title("Knife4j標題")
.description("Knife4j說明")
.version("v1")
.contact(new Contact().name("robin").email("[email protected]"))
.license(new License().name("Apache 2.0").url("http://springdoc.org"))
);
}
}
3.編寫User類用作模型
package com.mcode.knife4jdemo.entity;
import io.swagger.v3.oas.annotations.media.Schema;
/**
* ClassName: User
* Package: com.mcode.knife4jdemo.entity
* Description:
*
* @Author: robin
* @Version: v1.0
*/
@Schema(description = "使用者實體")
public class User {
@Schema(description = "使用者名稱稱")
private String userName;
@Schema(description = "密碼")
private String password;
@Schema(description = "郵箱")
private String email;
@Schema(description = "年齡")
private int age;
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public User() {
}
public User(String userName, String password, String email, int age) {
this.userName = userName;
this.password = password;
this.email = email;
this.age = age;
}
}
4.編寫控制器
package com.mcode.knife4jdemo.controller;
import com.mcode.knife4jdemo.entity.User;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.enums.ParameterIn;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.web.bind.annotation.*;
/**
* ClassName: IndexController
* Package: com.mcode.knife4jdemo.controller
* Description:
*
* @Author: robin
* @Version: v1.0
*/
@RestController
@Tag(name = "首頁")
@RequestMapping("/admin/index")
public class IndexController {
@Operation(summary = "獲取使用者")
@GetMapping("/getUser")
public User getUser( @Parameter(name = "userName",description = "使用者名稱稱",in = ParameterIn.QUERY)String userName) {
return new User(userName, "123456", "[email protected]", 18);
}
@Operation(summary = "新增使用者")
@PostMapping("/addUser")
public Boolean addUser(@RequestBody User user) {
return true;
}
}
SpringDoc註解具體可看:https://www.cnblogs.com/vic-tory/p/17690501.html
首頁
控制器