SpringBoot2.7.12整合Knife4j

SpringBoot2.7.12整合Knife4j
  • 是什么

    Knife4j是一个集Swagger2 OpenAPI3为一体的增强解决方案

  • 添加依赖

    <!--引入Knife4j的官方start包,该指南选择Spring Boot版本<3.0,开发者需要注意-->
    <dependency>
        <groupId>com.github.xiaoymin</groupId>
        <artifactId>knife4j-openapi2-spring-boot-starter</artifactId>
        <version>4.0.0</version>
    </dependency>
    
  • 创建配置类

    package com.example.demospringbootdemo.config;
    
    @Configuration
    @EnableSwagger2WebMvc
    public class Knife4jConfiguration {
         
        @Bean(value = "dockerBean")
        public Docket dockerBean() {
         
            //指定使用Swagger2规范
            Docket docket=new Docket(DocumentationType.SWAGGER_2)
                    .apiInfo(new ApiInfoBuilder()
                            //描述字段支持Markdown语法
                            .description("# Knife4j RESTful APIs")
                            .termsOfServiceUrl("https://itl-coder.github.io/")
                            .contact("ituninapp@gmail.com")
                            .version("1.0")
                            .build())
                    //分组名称
                    .groupName("用户服务")
                    .select()
                    //这里指定Controller扫描包路径
                    .apis(RequestHandlerSelectors.basePackage("com.example.demospringbootdemo.controller"))
                    .paths(PathSelectors.any())
                    .build();
            return docket;
        }
    }
    
    • 分组配置

      // @Bean public Docket deptDockerBean() { 部门管理的配置 }
      .groupName("部门管理").paths(PathSelectors.ant("/dept/**"))
      // @Bean public Docket empDockerBean() { 用户管理的配置 }
      .groupName("用户管理").paths(PathSelectors.ant("/emp/**"))
      

  • 控制器的使用

    • 实体类参数

      @RestController
      @Api(tags = "用户管理", description = "提供用户信息的接口")
      public class UserController {
             
          @ApiOperation(value = "对接口功能的说明", notes = "根据用户传入的信息返回用户对象")
          @GetMapping("/user")
          public User sayUser(User user) {
             
              return user;
          }
      }
      

    • 普通字段

      package com.example.demospringbootdemo.controller;
      
      
      @RestController
      @Api(tags = "用户管理", description = "提供用户信息的接口")
      public class UserController {
             
          @ApiOperation(value = "对接口功能的说明")
          @GetMapping("/hello")
          public String sayHello(
                  @ApiParam(name = "username", required = false, defaultValue = "coder-itl") String username,
                  @ApiParam(name = "password", required = true, defaultValue = "123") String password) {
             
              return username + " " + password;
          }
      }
      
  • 实体类使用

    @Data
    @NoArgsConstructor
    @AllArgsConstructor
    @ApiModel(value = "用户实体")
    public class User {
         
        @ApiModelProperty(value="姓名",example="张飞")
        private String username;
        @ApiModelProperty(value="密码",example="123",required = true)
        private Integer password;
    }
    
    

  • 启动

    http://localhost:8080/doc.html
    
  • 如何添加了拦截器,进行如下配置

    package com.example.demospringbootdemo.config;
    
    // @EnableWebMvc 不启用
    @Configuration
    public class SpringMvcConfig implements WebMvcConfigurer {
         
        @Autowired
        private GlobalInterceptor globalInterceptor;
    
        // 拦截器配置
        @Override
        public void addInterceptors(InterceptorRegistry registry) {
         
            registry.addInterceptor(globalInterceptor);
        }
        
        @Override
        public void addResourceHandlers(ResourceHandlerRegistry registry) {
         
            registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");
            registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
        }
    }
    
    

相关推荐

  1. Springboot整合Knife4j接口文档

    2023-12-31 00:46:02       36 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-31 00:46:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-31 00:46:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-31 00:46:02       82 阅读
  4. Python语言-面向对象

    2023-12-31 00:46:02       91 阅读

热门阅读

  1. for in 和for of 的区别(js)

    2023-12-31 00:46:02       54 阅读
  2. 第二百三十七回

    2023-12-31 00:46:02       45 阅读
  3. mysql_存储过程

    2023-12-31 00:46:02       62 阅读
  4. 测试的职业发展路径

    2023-12-31 00:46:02       59 阅读
  5. C++/Qt版餐厅点餐系统模块代码详解——点餐模块

    2023-12-31 00:46:02       56 阅读
  6. 微机原理12练习题答案

    2023-12-31 00:46:02       55 阅读
  7. js预加载和滚动到底部加载数据实现

    2023-12-31 00:46:02       48 阅读