springBoot整合swagger2

本文档介绍了如何在Spring Boot应用中集成Swagger2进行API文档的生成与管理,并提供了详细的配置步骤。同时,文章还涵盖了如何通过Nginx配置将Swagger UI的访问路径代理到应用服务器,确保在开发和测试环境中能够正常访问API文档。

1、导入jar

<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.9.2</version>
</dependency>
<dependency>
     <groupId>io.springfox</groupId>
     <artifactId>springfox-swagger2</artifactId>
     <version>2.9.2</version>
 </dependency>

2、代码配置类

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

/**
 1. swagger配置类
 */
@Configuration
@EnableSwagger2
//只在开发测试环境开放
@Profile({"dev","test"})
public class SwaggerConfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                //是否开启 (true 开启  false隐藏。生产环境建议隐藏)
                .enable(true)
                .select()
                //扫描的路径包,设置basePackage会将包下的所有被@Api标记类的所有方法作为api
     //.apis(RequestHandlerSelectors.basePackage("com.mcy.springbootswagger.controller"))
                .apis(RequestHandlerSelectors.any())
                //指定路径处理PathSelectors.any()代表所有的路径
                .paths(PathSelectors.any())
                .build();
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                //设置文档标题(API名称)
                .title("基础数据平台接口规范说明")
                //文档描述
                .description("接口说明")
                //服务条款URL
                .termsOfServiceUrl("https://www.apache.org/licenses/LICENSE-2.0")
                //版本号
                .version("1.0.0")
                .build();
    }
}

3、nginx配置:其他配置不动,加下面配置

location ~* ^(/v2|/webjars|/swagger-resources|/swagger-ui.html){
       proxy_set_header Host $host;
       proxy_set_header  X-Real-IP  $remote_addr;
       proxy_set_header X-Forwarded-For $remote_addr;
       #proxy_set_header Host $host:$server_port;
       proxy_set_header X-Forwarded-Proto $scheme;
       proxy_set_header X-Forwarded-Port $server_port;
       proxy_pass http://ip:9090; 
}

### SpringBoot 整合 Swagger2 示例教程 在 Spring Boot 项目中整合 Swagger2,可以通过引入相关依赖并进行适当的配置来实现。以下是具体的实现步骤和代码示例: #### 1. 添加依赖 需要在项目的 `pom.xml` 文件中添加以下依赖项: ```xml <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency> ``` 这些依赖分别用于生成 Swagger 文档和提供 Swagger UI 的可视化界面[^4]。 #### 2. 创建 Swagger 配置类 创建一个配置类,通过注解声明启动 Swagger 功能,并生成 `Docket` 实例: ```java 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.ApiInfo; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; @Configuration public class SwaggerConfig { @Bean public Docket api() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.basePackage("com.example.demo.controller")) .paths(PathSelectors.any()) .build(); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("Spring Boot 中使用 Swagger2 API 文档") .description("更多详情请参考官方文档") .version("1.0.0") .build(); } } ``` 上述代码中,`@Configuration` 注解声明该类为配置类,`@EnableSwagger2` 注解启用 Swagger 功能(注意:如果使用的是 Swagger3,则无需此注解)。`Docket` 实例定义了 API 文档的元数据和扫描规则[^2]。 #### 3. 启动项目并访问 Swagger UI 完成以上配置后,启动 Spring Boot 项目。默认情况下,可以通过以下地址访问 Swagger UI 界面: ``` http://localhost:8080/swagger-ui.html ``` 如果使用的是 Swagger3,则访问地址可能为: ``` http://localhost:8080/swagger-ui/ ``` #### 4. 测试接口 在控制器中定义一些测试接口,例如: ```java import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/api") public class ExampleController { @GetMapping("/hello") public String hello() { return "Hello, Swagger!"; } } ``` 启动项目后,在 Swagger UI 界面中可以查看并测试该接口。 --- ### 注意事项 - 如果项目中启用了 `@EnableWebMvc` 或自定义了 `WebMvcConfigurer`,可能会导致 Swagger 不生效。此时需要手动配置静态资源路径[^3]。 - 确保所有依赖版本一致,避免因版本不兼容导致的问题。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值