当前位置: 首页 > news >正文

SpringBoot整合knife4j

1. 导包

SpringBoot版本:2.3.7.RELEASE

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

2. 配置

import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.bean.validators.configuration.BeanValidatorPluginsConfiguration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.ParameterBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.schema.ModelRef;
import springfox.documentation.service.*;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spi.service.contexts.SecurityContext;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

@Configuration
@EnableSwagger2
@EnableKnife4j
@Import(BeanValidatorPluginsConfiguration.class)
public class Swagger2Config implements WebMvcConfigurer {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
    }

   
    @Bean(value = "defaultApi2")
    public Docket defaultApi2() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                //此包路径下的类,才生成接口文档
                .apis(RequestHandlerSelectors.basePackage("com.hebcph"))
                //加了ApiOperation注解的类,才生成接口文档
                .apis(RequestHandlerSelectors.withClassAnnotation(Api.class))
                .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                .paths(PathSelectors.any())
                .build()
                .securitySchemes(Collections.singletonList(securityScheme()))
                .securityContexts(securityContexts());
                //.globalOperationParameters(setHeaderToken());
    }

    
    @Bean
    SecurityScheme securityScheme() {
        return new ApiKey("X-ACCESS-TOKEN", "X-ACCESS-TOKEN", "header");
    }
   
    private List<Parameter> setHeaderToken() {
        ParameterBuilder tokenPar = new ParameterBuilder();
        List<Parameter> pars = new ArrayList<>();
        tokenPar.name("X-ACCESS-TOKEN").description("token").modelRef(new ModelRef("string")).parameterType("header").required(false).build();
        pars.add(tokenPar.build());
        return pars;
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                // //大标题
                .title("后台服务API接口文档")
                // 版本号
                .version("1.0")
//				.termsOfServiceUrl("NO terms of service")
                // 描述
                .description("后台API接口")
                .license("The Apache License, Version 2.0")
                .licenseUrl("http://www.apache.org/licenses/LICENSE-2.0.html")
                .build();
    }

    private List<SecurityContext> securityContexts() {
        return new ArrayList(
                Collections.singleton(SecurityContext.builder()
                        .securityReferences(defaultAuth())
                        .forPaths(PathSelectors.regex("^(?!auth).*$"))
                        .build())
        );
    }

    private List<SecurityReference> defaultAuth() {
        AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");
        AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];
        authorizationScopes[0] = authorizationScope;
        return new ArrayList(
                Collections.singleton(new SecurityReference("X-ACCESS-TOKEN", authorizationScopes)));
    }
}

3. 启动

http://localhost:8080/doc.html

tp

相关文章:

  • Dockerfile
  • 编译无法加载主类的问题
  • 【前端】Layui小功能收集整理
  • Android Kotlin 协程初探 | 京东物流技术团队
  • 如何在不恢复出厂设置的情况下解锁 Android 手机密码?
  • JavaScript 原型链污染
  • 在pyqt中,self.label_3.setScaledContents(True),论lable打开内容尺寸适应的重要性
  • Java面试题-UDP\TCP\HTTP
  • 第1篇 目标检测概述 —(3)目标检测评价指标
  • JSX 列表渲染
  • 【1024程序员节特刊】算法题目易错之处干货总结
  • 2023版 STM32实战11 SPI总线读写W25Q
  • RTI-DDS代码分析使用介绍
  • JAVA-编程基础-11-04-java IO 字符流
  • 设计模式-建造者模式
  • 汇编的指令
  • Linux下的命令行参数和环境变量
  • 【Git LFS】huggingface 断点续传
  • 【机器学习】模型平移不变性/等变性归纳偏置Attention机制
  • MATLAB R2023b安装包下载链接及软件安装教程
  • 屠呦呦当选美国科学院外籍院士
  • 中方发布《不跪!》视频传递何种信息?外交部回应
  • 君亭酒店:2024年营业收入约6.76亿元, “酒店行业传统增长模式面临巨大挑战”
  • 上海数学教育及数学科普专家陈永明去世,享年85岁
  • 一季度全国城镇新增就业308万人
  • 六朝文物草连空——丹阳句容南朝石刻考察纪