springboot项目集成swagger2
创始人
2025-05-29 06:08:51

pom依赖

2.7.0

io.springfoxspringfox-swagger2${swagger2.version}

io.springfoxspringfox-swagger-ui${swagger2.version}

application.yml配置

swagger:enable: true

创建SwaggerConfig配置类

在这里插入图片描述

package com.yyl.system.config;import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiKey;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.SecurityScheme;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;import java.util.ArrayList;
import java.util.List;/**
*
* @author  yangyile
* @since 2023-03-16 21:36
*/
@Configuration
@EnableSwagger2
public class SwaggerConfig {@Value("${swagger.enable}")private boolean swaggerEnable;@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.SWAGGER_2).enable(swaggerEnable).groupName("swagger").apiInfo(apiInfo()).select().apis(RequestHandlerSelectors.basePackage("com.yyl.system.controller")).apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)).paths(PathSelectors.any()).build().securitySchemes(unifiedAuth());}//    头部配置private ApiInfo apiInfo() {return new ApiInfoBuilder().title("Spring Boot中使用Swagger2构建RESTful APIs").contact("yangyile").termsOfServiceUrl("https://blog.csdn.net/y2010081134").version("1.0").build();}//    安全认证private static List unifiedAuth() {List arrayList = new ArrayList();arrayList.add(new ApiKey("token验证", "token", "header"));return arrayList;}
}

配置说明

@Configuration注解

表明该类是一个配置类,项目会自动引入swagger。

@EnableSwagger2注解

开启swagger。

@Value(“${swagger.enable}”)注解

指使用application.yml中swagger.enable的配置。

@Bean注解

注入spring容器,定制各个接口。

DocumentationType.SWAGGER_2

指定swagger版本类型。

enable方法

打开或者关闭swagger文档。

groupName方法

分组。

apiInfo方法

配置swagger的基本信息,如标题、作者、联系方式及版本等等。

select和apis方法

设置怎么扫描接口。RequestHandlerSelectors.basePackage(“com.yyl.system.controller”)表示只扫描controller包。RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)表示只对类上用@Api注解且方法上用@ApiOpearation的接口才会暴露给swagger。

paths方法

配置暴露给swagger的路由,PathSelectors.any()表示所有路由。也可以设置正则匹配。

securitySchemes方法

配置安全验证,这里设置token验证。

效果

在这里插入图片描述
未完待续。。。

相关内容

热门资讯

便利跨境往来 助力人文交流——...   2026年4月13日,中老铁路国际旅客列车迎来开通运营三周年。该趟列车使中国昆明与老挝万象之间实...
高市再提修宪 引发日本民众广泛...   日本执政党自由民主党12日在东京召开党大会。日本首相兼自民党总裁高市早苗再次表示将推进修宪,相关...
国际能源署:已准备好再次释放战...   △国际能源署署长法提赫·比罗尔(资料图)  国际能源署署长法提赫·比罗尔13日说,希望无需再次动...
乌拉圭驻华大使:期待推进乌中务...   新华社海口4月14日电(记者李欣)乌拉圭驻华大使阿尼瓦尔·卡夫拉尔13日在海南海口举行的第六届中...
视频 | 芬兰总统:美以“选择...   当地时间4月13日,正在美国访问的芬兰总统斯图布在一场智库活动上表示,在美以伊军事冲突中,伊朗目...