SpringBoot 整合 Swagger3.0 和 Knife4j

本文介绍了Knife4j这款轻量级的Swagger接口文档解决方案,包括其前身、pom.xml配置、Spring Boot集成、配置文件详解、访问地址和关键注解的使用。展示了如何通过注解自动生成详细的API文档,并提供了不同版本的访问路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、简介

  Knife4j的前身是swagger-bootstrap-ui,取名knife4j是希望她能像一把匕首一样小巧,轻量,并且功能强悍,更名也是希望把她做成一个为Swagger接口文档服务的通用性解决方案,不仅仅只是专注于前端Ui前端。

二、pom.xml

<!-- knife4j 3.0.2 相关依赖 -->
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-spring-boot-starter</artifactId>
    <version>3.0.2</version>
</dependency>

 三、配置文件

@Configuration
@EnableSwagger2    //开启 Swagger2
@EnableOpenApi     //开启 Swagger3,可以不写
@EnableKnife4j     //开启 knife4j,可以不写
public class Knife4jConfiguration {
    @Bean(value = "defaultApi3")
    public Docket defaultApi3() {
        
        // Swagger 2 使用的是:DocumentationType.SWAGGER_2
		// Swagger 3 使用的是:DocumentationType.OAS_30
        Docket docket = new Docket(DocumentationType.SWAGGER_2)
                // 定义是否开启swagger,false为关闭,可以通过变量控制
				.enable(true)
                .apiInfo(new ApiInfoBuilder()
                        .title("XXX服务平台Api接口文档")
                        .description("XXX服务平台Api接口文档")
                        .termsOfServiceUrl("http://127.0.0.1:8080/login")
                        .contact(new Contact("作者", "地址", "邮箱或联系方式"))
                        .version("1.0")
                        .build())
                //分组名称
                .groupName("XXX服务平台")
                .select()
                .apis(RequestHandlerSelectors.withClassAnnotation(RestController.class))
                //这里指定Controller扫描包路径
                //.apis(RequestHandlerSelectors.basePackage("com.chy.**.controller"))
                .paths(PathSelectors.any())
                .build();
        return docket;
    }
}

四、接口文档访问地址

knife4j 访问地址:http://localhost:8080/doc.html
Swagger2.0访问地址:http://localhost:8080/swagger-ui.html
Swagger3.0访问地址:http://localhost:8080/swagger-ui/index.html

五、注解说明

通过注解表明该接口会生成文档,包括接口名、请求方法、参数、返回信息的等等。

@Api:修饰整个类,描述Controller的作用。
@ApiOperation:描述一个类的一个方法,或者说一个接口。
@ApiParam:单个参数描述。
@ApiModel:描述接收参数的实体对象。
@ApiProperty:用对象接收参数时,描述对象的一个字段。
@ApiResponse:HTTP响应其中1个描述。
@ApiResponses:HTTP响应整体描述。
@ApiIgnore:使用该注解忽略这个API。
@ApiError :发生错误返回的信息。
@ApiImplicitParam:一个请求参数。
@ApiImplicitParams:多个请求参数。

### SpringBoot集成Swagger3.0访问路径404解决方案 在Spring Boot项目中集成Swagger3.0时,如果遇到访问路径返回404错误的情况,可能是由于以下几个原因引起的: #### 1. **版本兼容性问题** 从Spring Boot 2.6.0开始,默认使用`PathPatternParser`作为路径匹配器,而Swagger的旧版依赖仍然基于`AntPathMatcher`。这种不一致可能导致某些路径无法正常解析[^2]。 解决方法是在项目的`application.yml`文件中禁用新的路径模式解析器并恢复到传统的`AntPathMatcher`方式: ```yaml spring: mvc: pathmatch: matching-strategy: ant_path_matcher ``` #### 2. **引入正确的依赖** 确保项目中的Maven或Gradle配置包含了最新的Swagger支持库。对于Swagger3.0及以上版本,推荐使用以下依赖项[^1][^3]: ```xml <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency> ``` 注意:如果仅引入上述依赖仍无法解决问题,则可能需要额外添加Knife4j插件来增强功能支持更复杂的场景[^4]。 #### 3. **正确设置启动类上的注解** 根据所使用的Swagger具体版本调整应用主程序入口处的相关注解定义: - 对于低于3.0.0版本应标注为`@EnableSwagger2`; - 而等于或者高于此界限则替换成为`@EnableOpenApi`. 例如,在SpringBootApplication上加上如下声明即可完成初始化工作: ```java import springfox.documentation.swagger2.annotations.EnableSwagger2; @SpringBootApplication @EnableOpenApi // For Swagger 3.x versions. public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` #### 4. **确认资源映射地址无误** 随着Swagger迭代升级其默认UI页面位置也有所改变: - 版本号小于3.0.0时通过浏览器打开链接形如 `http://localhost:<port>/swagger-ui.html`. - 大于等于该临界点后需改访另一形式即 `http://localhost:<port>/swagger-ui/index.html#/` 或者简化后的 `/swagger-ui/`. 因此当发现请求失败提示找不到目标文件夹时候可以先核实当前安装包实际对应哪一类情况再做相应修改尝试重新加载网页查看效果如何. #### 示例代码片段展示完整流程 下面给出一段综合性的实现样例供参考学习之用: ```java @Configuration public class SwaggerConfig { @Bean public Docket api() { return new Docket(DocumentationType.OAS_30) .select() .apis(RequestHandlerSelectors.basePackage("com.example.demo.controller")) .paths(PathSelectors.any()) .build(); } } ``` --- ###
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值