当前位置:网站首页>什么是Knife4j?
什么是Knife4j?
2022-08-02 14:22:00 【半度纳】
Knife4j是一款可以提供在线API文档的框架,是基于Swagger框架实现的。
在Spring Boot项目中,使用Knife4j需要添加依赖knife4j-spring-boot-starter
:
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
<version>2.0.9</version>
</dependency>
然后,需要添加配置,则在某
项目的config
包下创建Knife4jConfig
类:
package cn.tedu.boot.demo.config;
import com.github.xiaoymin.knife4j.spring.extension.OpenApiExtensionResolver;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2WebMvc;
@Configuration
@EnableSwagger2WebMvc
public class Knife4jConfig {
/**
* 【重要】指定Controller包路径
*/
private String basePackage = "某.controller";
/**
* 分组名称
*/
private String groupName = "product";
/**
* 主机名
*/
private String host = "http://java.baidu.cn";
/**
* 标题
*/
private String title = "在线API文档--商品管理";
/**
* 简介
*/
private String description = "在线API文档--商品管理";
/**
* 服务条款URL
*/
private String termsOfServiceUrl = "http://www.apache.org/licenses/LICENSE-2.0";
/**
* 联系人
*/
private String contactName = "Java研发部";
/**
* 联系网址
*/
private String contactUrl = "http://baidu.cn";
/**
* 联系邮箱
*/
private String contactEmail = "[email protected]";
/**
* 版本号
*/
private String version = "1.0.0";
@Autowired
private OpenApiExtensionResolver openApiExtensionResolver;
@Bean
public Docket docket() {
String groupName = "1.0.0";
Docket docket = new Docket(DocumentationType.SWAGGER_2)
.host(host)
.apiInfo(apiInfo())
.groupName(groupName)
.select()
.apis(RequestHandlerSelectors.basePackage(basePackage))
.paths(PathSelectors.any())
.build()
.extensions(openApiExtensionResolver.buildExtensions(groupName));
return docket;
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title(title)
.description(description)
.termsOfServiceUrl(termsOfServiceUrl)
.contact(new Contact(contactName, contactUrl, contactEmail))
.version(version)
.build();
}
}
注意:必须修改以上配置中的包名,保证是当前项目中控制器类所在的包!其它各项均可不修改,以上配置代码可以从Knife4j的官网找到!
边栏推荐
猜你喜欢
随机推荐
DOM - Event Delegate
【TCP 和 UDP 基本原理】
小知识点系列:StringUtil.isEmpty()与StringUtil.isBlank()的区别
DOM —— 事件机制及事件链
BOM(Browser Object Model)浏览器对象模型相关概念
2022-02-14 第五小组 瞒春 学习笔记
js中的join()方法
Object.defineProperty方法(详解)
这几年让你大呼惊人的AI应用,都离不开这项技术
【时间序列模型】AR模型(原理剖析+MATLAB代码)
职工管理系统(SSM整合)
filebeat的配置
nodemon : 无法加载文件 D:\Program Files\nodejs\node_global\nodemon.ps1
2022-7-12 第五组 瞒春 学习报告
CSV file with the data read and write 】 【 XLS/XLSX file
[Time series model] AR model (principle analysis + MATLAB code)
一文让你快速写上扫雷游戏!童年的经典游戏,发给你的小女友让你装一波!!
【web渗透】文件包含漏洞入门级超详细讲解
2022-07-26 第六小组 瞒春 学习笔记
DOM —— 页面的渲染流程