[尚庭公寓]07-Knife快速入门

Knife快速入门

Knife4j是一个用于生成和展示API文档的工具,同时它还提供了在线调试的功能,下图是其工作界面。

  • Knife4j有多个版本,最新版的Knife4j基于开源项目`springdoc-openapi`,这个开源项目的核心功能就是根据SpringBoot项目中的代码自动生成符合OpenAPI规范的接口信息。

  • OpenAPI规范定义接口文档的内容和格式,其前身是`Swagger`规范。

与SpringBoot的集成相对简单,具体操作如下

  1. 创建SpringBoot项目

  2. 引入Maven 依赖

    com.github.xiaoymin knife4j-openapi3-jakarta-spring-boot-starter 4.3.0
  3. 创建配置类

创建`com.atguigu.helloknife4j.config.Knife4jConfiguration`,内容如下

复制代码
@Configuration
public class Knife4jConfiguration {

    @Bean
    public OpenAPI openAPI() {
        return new OpenAPI()
        .info(new Info()
              .title("hello-knife4j项目API")
              .version("1.0")
              .description("hello-knife4j项目的接口文档"));
    }

    @Bean
    public GroupedOpenApi userAPI() {
        return GroupedOpenApi.builder().group("用户信息管理").
        pathsToMatch("/user/**").
        build();
    }

    @Bean
    public GroupedOpenApi systemAPI() {
        return GroupedOpenApi.builder().group("产品信息管理").
        pathsToMatch("/product/**").
        build();
    }
}
  1. 启动项目

启动SpringBoot项目,访问http://localhost:8080/doc.html,观察接口文档。

Knife4j的使用也十分简单,我们只需使用几个简单注解,对接口进行描述,Knife4j就能自动生成API文档了。具体操作如下

  1. 描述实体类

创建`com.atguigu.helloknife4j.entity.User`,内容如下

复制代码
@Data
@Schema(description = "用户信息实体")
public class User {

    @Schema(description = "编号")
    private Long id;

    @Schema(description = "用户姓名")
    private String name;

    @Schema(description = "用户年龄")
    private Integer age;

    @Schema(description = "用户邮箱")
    private String email;
}

知识点: @Schema`注解用于描述作为接口参数或者返回值的实体类的数据结构。

  1. 描述Controller接口

创建`com.atguigu.helloknife4j.controller.HelloController`,内容如下

复制代码
@RestController
@RequestMapping("/user")
@Tag(name = "用户信息管理")
public class HelloController {


    @Operation(summary = "根据id获取用户信息")
    @GetMapping("getById")
    public User getUserById(@Parameter(description = "用户id") @RequestParam Long id) {
        User user = new User();
        user.setId(id);
        user.setName("zhangsan");
        user.setAge(11);
        user.setEmail("zhangsan@email.com");
        return user;
    }
}

知识点:

`@Tag`注解用于对接口进行分类,相同`Tag`的接口会放在同一个菜单。

`@Operation`用于对接口进行描述。

`@Parameter`用于对HTTP请求参数进行描述

相关推荐
Flittly16 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了16 小时前
Java 生成二维码解决方案
java·后端
人活一口气20 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP1 天前
Vibe Coding -- 完整项目案例实操
java
荣码1 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing1 天前
Google第三方授权登录
java·后端·程序员
明月光8181 天前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路2 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java