当前位置:网站首页>什么是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的官网找到!
边栏推荐
猜你喜欢
随机推荐
XML技术
velocity模板页面四则运算
lammps学习(二)联合原子模型聚乙烯拉伸
MATLAB文件操作
【面经】被虐了之后,我翻烂了equals源码,总结如下
DOM — 元素的增删改查
Spark的概念、特点、应用场景
异常简单总结
【网络参考模型】
DOM —— 事件机制及事件链
Impulse response invariant method and bilinear transformation method for IIR filter design
Nvm,Nrm使用教程
Redis + Caffeine实现多级缓存
Servlet 技术1
2022-0801 第六小组 瞒春 学习笔记
VsCode更新后,怎么使用使用快捷键同时生成多个元素
双亲委派机制
Explain in detail how the bit manipulation operators in C language can be used?
【滤波器】最小均方(LMS)自适应滤波器
Filter 过滤器









