SpringBoot集成knife4j接口文档
0. 导入maven依赖
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
1. 创建knife4j配置类
@Configuration
public class Knife4jConfiguration {
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("SpringBoot整合Knife4j-api接口文档")
.description("本文档描述了SpringBoot如何整合Knife4j")
.version("1.0")
.build();
}
@Bean
public Docket adminApiConfig() {
Docket adminConfig = new Docket(DocumentationType.SWAGGER_2)
.groupName("后台管理接口")
.apiInfo(apiInfo())
.select()
//只显示admin路径下的页面
.apis(RequestHandlerSelectors.basePackage("com.sky.controller"))
.paths(PathSelectors.regex("/admin/.*"))
.build();
return adminConfig;
}
@Bean
public Docket userApiConfig() {
Docket adminConfig = new Docket(DocumentationType.SWAGGER_2)
.groupName("用户端管理接口")
.apiInfo(apiInfo())
.select()
//只显示user路径下的页面
.apis(RequestHandlerSelectors.basePackage("com.sky.controller"))
.paths(PathSelectors.regex("/user/.*"))
.build();
return adminConfig;
}
}
2. 使用knife4j
常用注解:
注解 | 使用 |
---|---|
@ApiModel("实体类描述") | 在实体类使用 |
@ApiModelProperty("实体类属性描述") | 在实体类属性使用 |
@Api(tags = "controller描述") | 在controller使用 |
@ApiOperation(value = "api操作描述") | 在controller内请求方法使用 |
3. 效果
后台管理接口:
用户端接口:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南