Springboot中Knife4j快速入门

概述

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

了解

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

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

与SpringBoot集成

引入Maven 依赖

<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
    <version>4.3.0</version>
</dependency>

创建配置类

在config包下面创建一个配置类Knife4jConfiguration

package com.example.helloknf4j.config;

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import org.springdoc.core.models.GroupedOpenApi;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@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();
    }
}

启动项目

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

基本使用

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

  1. 描述实体类

    在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注解用于描述作为接口参数或者返回值的实体类的数据结构。

  2. 描述Controller接口

    创建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请求参数进行描述

注:以上注解不是非必须的,而是通过描述一下,显示的更加直观和清楚

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值