点击上方 好好学java ,选择 星标 公众号重磅资讯,干货,第一时间送达
今日推荐:推荐 19 个 github 超牛逼项目!个人原创100W +访问量博客:点击前往,查看更多

作者:飞翔的大白菜

blog.csdn.net/wangzhihao1994/article/details/108408420

资料

  • swagger 官网:swagger.io

  • springfox 官网:springfox

  • springfox Github 仓库:springfox / springfox

  • springfox-demos Github 仓库:springfox / springfox-demos

  • springfox Maven 仓库:Home » io.springfox

swagger介绍

对于 Rest API 来说很重要的一部分内容就是文档,Swagger 为我们提供了一套通过代码和注解自动生成文档的方法,这一点对于保证 API 文档的及时性将有很大的帮助。

Swagger 是一套基于 OpenAPI 规范(OpenAPI Specification,OAS)构建的开源工具,可以帮助我们设计、构建、记录以及使用 Rest API。

OAS本身是一个API规范,它用于描述一整套API接口,包括一个接口是哪种请求方式、哪些参数、哪些header等,都会被包括在这个文件中。它在设计的时候通常是YAML格式,这种格式书写起来比较方便,而在网络中传输时又会以json形式居多,因为json的通用性比较强。

Swagger 主要包含了以下三个部分:

  • Swagger Editor:基于浏览器的编辑器,我们可以使用它编写我们 OpenAPI 规范。

  • Swagger UI:它会将我们编写的 OpenAPI 规范呈现为交互式的 API 文档,后文我将使用浏览器来查看并且操作我们的 Rest API。

  • Swagger Codegen:它可以通过为 OpenAPI(以前称为 Swagger)规范定义的任何 API 生成服务器存根和客户端 SDK 来简化构建过程。

springfox介绍

由于Spring的流行,Marty Pitt编写了一个基于Spring的组件swagger-springmvc,用于将swagger集成到springmvc中来,而springfox则是从这个组件发展而来。

通常SpringBoot项目整合swagger需要用到两个依赖:springfox-swagger2springfox-swagger-ui,用于自动生成swagger文档。

  • springfox-swagger2:这个组件的功能用于帮助我们自动生成描述API的json文件

  • springfox-swagger-ui:就是将描述API的json文件解析出来,用一种更友好的方式呈现出来。

SpringFox 3.0.0 发布

官方说明:

  • SpringFox 3.0.0 发布了,SpringFox 的前身是 swagger-springmvc,是一个开源的 API doc 框架,可以将 Controller 的方法以文档的形式展现。

  • 首先,非常感谢社区让我有动力参与这个项目。在这个版本中,在代码、注释、bug报告方面有一些非常惊人的贡献,看到人们在问题论坛上跳槽来解决问题,我感到很谦卑。它确实激励我克服“困难”,开始认真地工作。有什么更好的办法来摆脱科维德的忧郁!

  • 注意:这是一个突破性的变更版本,我们已经尽可能地保持与springfox早期版本的向后兼容性。在2.9之前被弃用的api已经被积极地删除,并且标记了将在不久的将来消失的新api。所以请注意这些,并报告任何遗漏的内容。

新特性:

  • Remove explicit dependencies on springfox-swagger2

  • Remove any @EnableSwagger2… annotations

  • Add the springfox-boot-starter dependency

  • Springfox 3.x removes dependencies on guava and other 3rd party libraries (not zero dep yet! depends on spring plugin and open api libraries for annotations and models) so if you used guava predicates/functions those will need to transition to java 8 function interfaces.

此版本的亮点:

  • Spring5,Webflux支持(仅支持请求映射,尚不支持功能端点)。

  • Spring Integration支持(非常感谢反馈)。

  • SpringBoot支持springfox Boot starter依赖性(零配置、自动配置支持)。

  • 具有自动完成功能的文档化配置属性。

  • 更好的规范兼容性与2.0。

  • 支持OpenApi 3.0.3。

  • 零依赖。几乎只需要spring-plugin,swagger-core ,现有的swagger2注释将继续工作并丰富openapi3.0规范。

兼容性说明:

  • 需要Java 8

  • 需要Spring5.x(未在早期版本中测试)

  • 需要SpringBoot 2.2+(未在早期版本中测试)

注意:

应用主类增加注解@EnableOpenApi,删除之前版本的SwaggerConfig.java。

启动项目,访问地址:http://localhost:8080/swagger-ui/index.html,注意2.x版本中访问的地址的为http://localhost:8080/swagger-ui.html

整合使用

Maven项目中引入springfox-boot-starter依赖:

<dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version>
</dependency>
12345

application.yml配置

spring:application:name: springfox-swagger
server:port: 8080# ===== 自定义swagger配置 ===== #
swagger:enable: trueapplication-name: ${spring.application.name}application-version: 1.0application-description: springfox swagger 3.0整合Demotry-host: http://localhost:${server.port}
12345678910111213

使用@EnableOpenApi注解,启用swagger配置

@EnableOpenApi
@Configuration
public class SwaggerConfiguration {}
12345

自定义swagger配置类SwaggerProperties

@Component
@ConfigurationProperties("swagger")
public class SwaggerProperties {/*** 是否开启swagger,生产环境一般关闭,所以这里定义一个变量*/private Boolean enable;/*** 项目应用名*/private String applicationName;/*** 项目版本信息*/private String applicationVersion;/*** 项目描述信息*/private String applicationDescription;/*** 接口调试地址*/private String tryHost;public Boolean getEnable() {return enable;}public void setEnable(Boolean enable) {this.enable = enable;}public String getApplicationName() {return applicationName;}public void setApplicationName(String applicationName) {this.applicationName = applicationName;}public String getApplicationVersion() {return applicationVersion;}public void setApplicationVersion(String applicationVersion) {this.applicationVersion = applicationVersion;}public String getApplicationDescription() {return applicationDescription;}public void setApplicationDescription(String applicationDescription) {this.applicationDescription = applicationDescription;}public String getTryHost() {return tryHost;}public void setTryHost(String tryHost) {this.tryHost = tryHost;}
}
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768

一个完整详细的springfox swagger配置示例:

import io.swagger.models.auth.In;
import org.apache.commons.lang3.reflect.FieldUtils;
import org.springframework.boot.SpringBootVersion;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.util.ReflectionUtils;
import org.springframework.web.servlet.config.annotation.InterceptorRegistration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.oas.annotations.EnableOpenApi;
import springfox.documentation.service.*;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spi.service.contexts.SecurityContext;
import springfox.documentation.spring.web.plugins.Docket;import java.lang.reflect.Field;
import java.util.*;@EnableOpenApi
@Configuration
public class SwaggerConfiguration implements WebMvcConfigurer {private final SwaggerProperties swaggerProperties;public SwaggerConfiguration(SwaggerProperties swaggerProperties) {this.swaggerProperties = swaggerProperties;}@Beanpublic Docket createRestApi() {return new Docket(DocumentationType.OAS_30).pathMapping("/")// 定义是否开启swagger,false为关闭,可以通过变量控制.enable(swaggerProperties.getEnable())// 将api的元信息设置为包含在json ResourceListing响应中。.apiInfo(apiInfo())// 接口调试地址.host(swaggerProperties.getTryHost())// 选择哪些接口作为swagger的doc发布.select().apis(RequestHandlerSelectors.any()).paths(PathSelectors.any()).build()// 支持的通讯协议集合.protocols(newHashSet("https", "http"))// 授权信息设置,必要的header token等认证信息.securitySchemes(securitySchemes())// 授权信息全局应用.securityContexts(securityContexts());}/*** API 页面上半部分展示信息*/private ApiInfo apiInfo() {return new ApiInfoBuilder().title(swaggerProperties.getApplicationName() + " Api Doc").description(swaggerProperties.getApplicationDescription()).contact(new Contact("lighter", null, "123456@gmail.com")).version("Application Version: " + swaggerProperties.getApplicationVersion() + ", Spring Boot Version: " + SpringBootVersion.getVersion()).build();}/*** 设置授权信息*/private List<SecurityScheme> securitySchemes() {ApiKey apiKey = new ApiKey("BASE_TOKEN", "token", In.HEADER.toValue());return Collections.singletonList(apiKey);}/*** 授权信息全局应用*/private List<SecurityContext> securityContexts() {return Collections.singletonList(SecurityContext.builder().securityReferences(Collections.singletonList(new SecurityReference("BASE_TOKEN", new AuthorizationScope[]{new AuthorizationScope("global", "")}))).build());}@SafeVarargsprivate final <T> Set<T> newHashSet(T... ts) {if (ts.length > 0) {return new LinkedHashSet<>(Arrays.asList(ts));}return null;}/*** 通用拦截器排除swagger设置,所有拦截器都会自动加swagger相关的资源排除信息*/@SuppressWarnings("unchecked")@Overridepublic void addInterceptors(InterceptorRegistry registry) {try {Field registrationsField = FieldUtils.getField(InterceptorRegistry.class, "registrations", true);List<InterceptorRegistration> registrations = (List<InterceptorRegistration>) ReflectionUtils.getField(registrationsField, registry);if (registrations != null) {for (InterceptorRegistration interceptorRegistration : registrations) {interceptorRegistration.excludePathPatterns("/swagger**/**").excludePathPatterns("/webjars/**").excludePathPatterns("/v3/**").excludePathPatterns("/doc.html");}}} catch (Exception e) {e.printStackTrace();}}}
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121

一些常用注解说明

  • @Api:用在controller类,描述API接口

  • @ApiOperation:描述接口方法

  • @ApiModel:描述对象

  • @ApiModelProperty:描述对象属性

  • @ApiImplicitParams:描述接口参数

  • @ApiResponses:描述接口响应

  • @ApiIgnore:忽略接口方法

示例

项目Demo:springfox-swagger

效果图:example

参考

  • 在 Spring Boot 项目中使用 Swagger 文档

  • Springfox 3.0.0(包含springfox-swagger2-3.0.0)即OpenAPI 3的发布与系统集成

推荐文章
  • 开发者工具 Top 100 名单

  • 2020年国内互联网公司的薪酬排名!

  • 不要再封装各种Util工具类了,这个神级框架值得拥有!

  • 写博客能月入10K?

  • 一款基于 Spring Boot 的现代化社区(论坛/问答/社交网络/博客)

更多项目源码
  • 这或许是最美的Vue+Element开源后台管理UI

  • 推荐一款高颜值的 Spring Boot 快速开发框架

  • 一款基于 Spring Boot 的现代化社区(论坛/问答/社交网络/博客)

  • 13K点赞都基于 Vue+Spring 前后端分离管理系统ELAdmin,大爱

  • 想接私活时薪再翻一倍,建议根据这几个开源的SpringBoot项目

重磅:Swagger3.0 官方 starter 诞生了,其它的都可以扔了~相关推荐

  1. Swagger3.0官方starter诞生,可以扔掉那些野生starter了

    原创:猿逻辑,欢迎分享,转载请保留出处. Swagger是研发的好帮手,可以减少前后端的很多沟通成本.甚至在一些比较高级的公司,还能减少和测试人员的沟通成本.所以只要一个项目采用了SpringBoot ...

  2. Swagger 官方 Starter 配上这个增强方案是真的香!

    这篇文章,简单给大家聊聊项目必备的 Swagger 该怎么玩. 何为 Swagger ? 简单来说,Swagger 就是一套基于 OpenAPI 规范构建的开源工具,可以帮助我们设计.构建.记录以及使 ...

  3. Swagger 3.0 官方教材出炉,野生的可以扔了!

    点击"开发者技术前线",选择"星标????" 让一部分开发者看到未来 链接:blog.csdn.net/wangzhihao1994/article/detai ...

  4. Swagger3.0快速开发及空指针异常的解决

    目录 前言 一.配置类配置Swagger 二.属性文件配置Swagger 三.配置多个分组 四.配置扫描接口 五.空指针异常 前言 Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 ...

  5. 七彩智能组卷软件系统 V4.9.0.0官方版

    名称:七彩智能组卷软件系统 V4.9.0.0官方版 版本:4.9.0.0 软件大小:2 MB 软件语言:简体中文 软件授权:免费版 应用平台:Win8/Win7/WinXP 七彩智能组卷终身免费版(精 ...

  6. Spring Boot中使用Swagger3.0.0版本构建RESTful APIs

    文章目录 一.项目描述 二.简介 三.Swagger2.X和Swagger3.0.0 的对比 1)SpringFox 2.x 发布 2)SpringFox 3.0.0 发布 3)swagger3.0 ...

  7. 程序安装包制作工具 v1.0官方版

    2019独角兽企业重金招聘Python工程师标准>>> 名称:程序安装包制作工具 v1.0官方版 版本:1.0更新日期:2016-06-27 大小:2.9MB软件语言:简体中文 软件 ...

  8. python3-Python3.7.0官方版

    Python3.7.0官方版是一种相当靠谱和出众的通用型语言.Python3.7.0官方版被广泛使用,提供了丰富全面的模块,并支持sockets编程,可以非常方便快速地开发分布式应用程序,同时还有PI ...

  9. SpringBoot实战教程(1)| 整合Swagger3.0.0

    本文教你如何在SpringBoot中整合Swagger,快速实现在线接口文档. Swagger版本:3.0.0 SpringBoot版本:2.5.6 目录 一.初始化SpringBoot项目 二.引入 ...

最新文章

  1. 项目立项管理:招投标
  2. 二十万字C/C++、嵌入式软开面试题全集宝典六
  3. 二、window下django安装及第一个应用
  4. ubuntu下Anaconda安装gym包
  5. re:Invent 大会第一天,看看AWS有哪些最新进展?\n
  6. 线性汇编总结和函数说明
  7. 计算机应用技术的创新
  8. 库克连夜从谷歌抢人,阻止 Siri 继续变傻!
  9. 下血本买的!2021Java高级面试题
  10. obs中音频和视频的同步
  11. 【转】 Git 常用命令详解(二)----不错
  12. 手工笔筒制作教程(附彩色贴图分享)
  13. cocos ClippingNode 之绘制六边形战力(一)
  14. CCW:浪潮云+智能协同云平台获评“用户首选品牌”
  15. SpringCloud熔断机制大概什么意思
  16. 你心有喜欢的明星吗??
  17. 不给代码写文档,让代码文档化
  18. 纯css3 夜晚天空月亮动画特效(源码公益站)
  19. NCBI中各个符号代表意思
  20. C++入门:命名空间

热门文章

  1. 服务器控件的异步请求——UpdatePanel和ScriptManager
  2. Oracle10g的flashback drop
  3. linux mktime函数会受当前环境变量设置的时区影响
  4. QPainter中坐标系变换问题
  5. AB1601开机运行后死机
  6. linux驱动篇之 driver_register 过程分析(一)
  7. XGBoost Plotting API以及GBDT组合特征实践
  8. 双线程猜数字 TwoThreadGuessNumber.java
  9. load、loads、dump、dumps的区别
  10. python—多线程定义和创建(一)