当前位置:网站首页>什么是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的官网找到!
边栏推荐
- Window function method for FIR filter design
- 一、QT界面开发 --QT安装
- DOM — 元素的增删改查
- DOM —— 事件代理
- Impulse response invariant method and bilinear transformation method for IIR filter design
- IDEA如何进行远程Debug
- VLAN原理
- Based on the SVM regression forecast 】 【 LibSVM realize the prediction of a characteristic data
- Servlet 技术1
- 只出现一次的数字||| —— 哈希映射、异或位运算+分治思想
猜你喜欢
随机推荐
【时间序列模型】AR模型(原理剖析+MATLAB代码)
DOM - Event Mechanism and Event Chain
【滤波器】最小均方(LMS)自适应滤波器
延时函数-定时器
nvm详细安装步骤以及使用(window10系统)
2022-07-25 第六小组 瞒春 学习笔记
【web渗透】文件包含漏洞入门级超详细讲解
2022-07-29 第六小组 瞒春 学习笔记
VsCode更新后,怎么使用使用快捷键同时生成多个元素
DOM —— 事件绑定与解绑
2022-07-13 第五小组 瞒春 学习笔记
2022-07-18 第五小组 瞒春 学习笔记
VLAN原理
Servlet 技术2
Jenkins 参数化构建(Extended Choice Parameter)
【JS执行机制】
我的第一篇博客
scroll、offset、client事件的用法及区别
BOM(Browser Object Model)浏览器对象模型相关概念
MATLAB file operations