1. 简介

  随着现在主流的前后端分离模式开发越来越成熟,接口文档的编写和规范是一件非常重要的事。简单的项目来说,对应的controller在一个包路径下,因此在Swagger配置参数时只需要配置一个包路径即可。但是对于复杂的项目,往往需要分模块开发,因此对应的controller包存在多个,所以需要在Swagger配置参数时需要指定多个包路径扫描。

  在一些普遍情况下,分模块开发时由不同的开发小组来完成,为了保证接口文档的风格统一和方便,在公共模块指定统一的配置工具类,其他模块只需要配置自己的模块名称、编码和指定包路径,即可完成接口文档的配置,大大方便管理和开发。

2. Swagger2相关文章

  SpringBoot整合Swagger2详细教程

3. Swagger配置多个包路径扫描示例代码

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import com.google.common.base.Function;
import com.google.common.base.Optional;
import com.google.common.base.Predicate; import springfox.documentation.RequestHandler;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2; /**
* Swagger2配置类
*
* @author CL
*
*/
@Configuration
@EnableSwagger2
public class Swagger2Config { /**
* 定义分隔符
*/
private static final String splitor = ";"; /**
* 注入Docket
*
* @return
*/
@Bean
public Docket docket() {
String basePackages = "com.c3stones.sys.controller" + splitor + "com.c3stones.common.controller";
return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select().apis(basePackage(basePackages))
.paths(PathSelectors.any()).build();
} /**
* 声明基础包
*
* @param basePackage 基础包路径
* @return
*/
public static Predicate<RequestHandler> basePackage(final String basePackage) {
return input -> declaringClass(input).transform(handlerPackage(basePackage)).or(true);
} /**
* 校验基础包
*
* @param basePackage 基础包路径
* @return
*/
private static Function<Class<?>, Boolean> handlerPackage(final String basePackage) {
return input -> {
for (String strPackage : basePackage.split(splitor)) {
boolean isMatch = input.getPackage().getName().startsWith(strPackage);
if (isMatch) {
return true;
}
}
return false;
};
} /**
* 检验基础包实例
*
* @param requestHandler 请求处理类
* @return
*/
@SuppressWarnings("deprecation")
private static Optional<? extends Class<?>> declaringClass(RequestHandler requestHandler) {
return Optional.fromNullable(requestHandler.declaringClass());
} /**
* 配置在线文档的基本信息
*
* @return
*/
private static ApiInfo apiInfo() {
return new ApiInfoBuilder().title("SpringBoot集成Swagger2并配置多个包路径扫描示例")
.contact(new Contact("Powered By C3Stones", "https://www.cnblogs.com/cao-lei", null))
.termsOfServiceUrl("https://www.cnblogs.com/cao-lei/").version("V1.0").build();
} }

4. 多模块分工开发时配置

  • 定义公共配置类
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.ResponseBody; import com.google.common.base.Function;
import com.google.common.base.Optional;
import com.google.common.base.Predicate;
import com.google.common.base.Predicates; import springfox.documentation.RequestHandler;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2; /**
* Swagger2配置工具类
*
* @author CL
*
*/
@Component
@EnableSwagger2
public class Swagger2ConfigUtils { /**
* 配置模块
*
* @param moduleCode 模块Code
* @param moduleName 模块名称
* @param basePackage 基础包(多个)
* @return
*/
public static Docket docket(String moduleCode, String moduleName, String... basePackage) {
return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo(moduleName)).groupName(moduleCode).select()
.apis(Predicates.and(RequestHandlerSelectors.withMethodAnnotation(ResponseBody.class),
basePackage(basePackage)))
.build();
} /**
* 声明基础包
*
* @param basePackage 基础包路径
* @return
*/
public static Predicate<RequestHandler> basePackage(final String... basePackage) {
return input -> declaringClass(input).transform(handlerPackage(basePackage)).or(true);
} /**
* 校验基础包
*
* @param basePackage 基础包路径
* @return
*/
private static Function<Class<?>, Boolean> handlerPackage(final String... basePackage) {
return input -> {
for (String strPackage : basePackage) {
boolean isMatch = input.getPackage().getName().startsWith(strPackage);
if (isMatch) {
return true;
}
}
return false;
};
} /**
* 检验基础包实例
*
* @param requestHandler 请求处理类
* @return
*/
@SuppressWarnings("deprecation")
private static Optional<? extends Class<?>> declaringClass(RequestHandler requestHandler) {
return Optional.fromNullable(requestHandler.declaringClass());
} /**
* 配置在线文档的基本信息
*
* @return
*/
private static ApiInfo apiInfo(String moduleName) {
return new ApiInfoBuilder().title(moduleName)
.contact(new Contact("Powered By C3Stones", "https://www.cnblogs.com/cao-lei", null))
.termsOfServiceUrl("https://www.cnblogs.com/cao-lei/").version("V1.0").build();
} }
  • 在其他模块中使用

      例如:核心模块、商城模块。
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import com.c3stones.common.utils.Swagger2ConfigUtils; import springfox.documentation.spring.web.plugins.Docket; /**
* Core模块Swagger2配置类
*
* @author CL
*
*/
@Configuration
public class CoreSwagger2Config { /**
* 新增Core模块
*
* @return
*/
@Bean
public Docket coreApi() {
String moduleCode = "core";
String moduleName = "核心模块";
String[] basePackage = { "com.c3stones.sys.controller", "com.c3stones.common.controller" };
return Swagger2ConfigUtils.docket(moduleCode, moduleName, basePackage);
} }
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import com.c3stones.common.utils.Swagger2ConfigUtils; import springfox.documentation.spring.web.plugins.Docket; /**
* Shop模块Swagger2配置类
*
* @author CL
*
*/
@Configuration
public class ShopSwagger2Config { /**
* 新增Shop模块
*
* @return
*/
@Bean
public Docket shopApi() {
String moduleCode = "shop";
String moduleName = "商城模块";
String basePackage = "com.c3stones.order.controller";
return Swagger2ConfigUtils.docket(moduleCode, moduleName, basePackage);
} }
  • 启动项目

5. 测试

  • 浏览器访问
# 因为使用了其他的Swagger UI(https://github.com/xiaoymin/swagger-bootstrap-ui),因此路径变为/doc.html
# 若使用原生的UI,则请求:http://127.0.0.1:8080/swagger-ui.html http://127.0.0.1:8080/doc.html
  • 截图(原生UI和新UI)



6. 项目地址

  spring-boot-swagger2-demo2

SpringBoot集成Swagger2并配置多个包路径扫描的更多相关文章

  1. SpringBoot集成Swagger2实现Restful(类型转换错误解决办法)

    1.pom.xml增加依赖包 <dependency> <groupId>io.springfox</groupId> <artifactId>spri ...

  2. springboot集成swagger2构建RESTful API文档

    在开发过程中,有时候我们需要不停的测试接口,自测,或者交由测试测试接口,我们需要构建一个文档,都是单独写,太麻烦了,现在使用springboot集成swagger2来构建RESTful API文档,可 ...

  3. SpringBoot集成Swagger2在线文档

    目录 SpringBoot集成Swagger2在线文档 前言 集成SpringBoot 登录接口文档示例 代码 效果 注解说明 总结 SpringBoot集成Swagger2在线文档 前言 不得不说, ...

  4. springboot 集成swagger2.x 后静态资源报404

    package com.bgs360.configuration; import org.springframework.context.EnvironmentAware; import org.sp ...

  5. springboot集成swagger2报Illegal DefaultValue null for parameter type integer

    springboot集成swagger2,实体类中有int类型,会报" Illegal DefaultValue null for parameter type integer"的 ...

  6. springboot 集成swagger2

    使用Swagger 可以动态生成Api接口文档,在项目开发过程中可以帮助前端开发同事减少和后端同事的沟通成本,而是直接参照生成的API接口文档进行开发,提高了开发效率.这里以springboot(版本 ...

  7. [转] spring-boot集成swagger2

    经测,spring-boot版本使用1.5.2+时需使用springfox-swagger2版本2.5+(spring-boot 1.2 + springfox-swagger2 2.2 在未扫描ja ...

  8. SpringBoot 集成Swagger2自动生成文档和导出成静态文件

    目录 1. 简介 2. 集成Swagger2 2.1 导入Swagger库 2.2 配置Swagger基本信息 2.3 使用Swagger注解 2.4 文档效果图 3. 常用注解介绍 4. Swagg ...

  9. 【java框架】SpringBoot(3) -- SpringBoot集成Swagger2

    1.SpringBoot web项目集成Swagger2 1.1.认识Swagger2 Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体 ...

随机推荐

  1. CTF-WEB-HCTF 2018 Warmup

    题目链接 攻防世界-Warmup 解题思路 [原题复现]HCTF 2018 Warmup(文件包含)

  2. [原题复现]2019强网杯WEB-随便注(多种方法)

    简介 原题复现:https://gitee.com/xiaohua1998/qwb_2019_supersqli  考察知识点:SQL注入漏洞-堆叠注入  线上平台:https://buuoj.cn( ...

  3. laravel 验证器使用

    1.前后端不分离 (form表单提交) 控制器定义验证规则 <?php namespace App\Http\Controllers\Admin; use Illuminate\Http\Req ...

  4. Redis 用的很溜,了解过它用的什么协议吗?

    我是风筝,公众号「古时的风筝」,一个兼具深度与广度的程序员鼓励师,一个本打算写诗却写起了代码的田园码农! 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在 ...

  5. 攻克solo第六课(大调音阶与真的爱你)

    在本期文章中,笔者将通过guitar pro7和大家分享大调音阶的知识. 不知道大家有没有试着使用my song book里面的谱子,反正笔者是觉得赚大了,并且找了囊括民谣.爵士到摇滚在内不同风格的谱 ...

  6. 如何使用MathType输入贝塔符号?

    在文档中使用公式,常常需要输入各种符号.比如要输入三角函数公式,那么就要输入三角函数中的阿尔法α.贝塔β等符号,那么要怎么打出这类符号呢? MathType作为强大的数学公式编辑器,可以用来编辑各种数 ...

  7. Golang 实现 Redis(7): Redis 集群与一致性 Hash

    本文是使用 golang 实现 redis 系列的第七篇, 将介绍如何将单点的缓存服务器扩展为分布式缓存.godis 集群的源码在Github:Godis/cluster 单台服务器的CPU和内存等资 ...

  8. bash反弹shell检测

    1.进程 file descriptor 异常检测 检测 file descriptor 是否指向一个socket 以重定向+/dev/tcp Bash反弹Shell攻击方式为例,这类反弹shell的 ...

  9. LNMP 一键安装脚本

    这个脚本是使用shell编写,为了快速在生产环境上部署lnmp/lamp/lnmpa(Linux.Nginx/Tengine/OpenResty.MySQL/MariaDB/Percona.PHP), ...

  10. Java8 Stream:2万字20个实例,玩转集合的筛选、归约、分组、聚合

    点波关注不迷路,一键三连好运连连! 先贴上几个案例,水平高超的同学可以挑战一下: 从员工集合中筛选出salary大于8000的员工,并放置到新的集合里. 统计员工的最高薪资.平均薪资.薪资之和. 将员 ...