点击“开发者技术前线”,选择“星标????”

让一部分开发者看到未来

链接:blog.csdn.net/wangzhihao1994/article/details/108408420

开始之前,先来看看 swagger3.0 相关的一些资料。

相关资料

  • swagger 官网:swagger.io[1]

  • springfox 官网:springfox[2]

  • springfox Github 仓库:springfox / springfox[3]

  • springfox-demos Github 仓库:springfox / springfox-demos[4]

  • springfox Maven 仓库:Home » io.springfox[5]

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文档。Spring Boot 集成 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[6] ,现有的swagger2注释将继续工作并丰富openapi3.0规范。

兼容性说明:

  • 需要Java 8

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

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

关注公众号开发者技术前线可以阅读 Java 8+ / Spring Boot系列教程

注意:应用主类增加注解@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

基础的不介绍了,不懂的可以看下 Spring Boot 学习实战仓库:https://github.com/javastacks/spring-boot-best-practice

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

@EnableOpenApi
@Configuration
public class SwaggerConfiguration {}

自定义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;}
}

一个完整详细的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();}}}

一些常用注解说明

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

  • @ApiOperation:描述接口方法

  • @ApiModel:描述对象

  • @ApiModelProperty:描述对象属性

  • @ApiImplicitParams:描述接口参数

  • @ApiResponses:描述接口响应

  • @ApiIgnore:忽略接口方法

示例

项目Demo:springfox-swagger[7]

效果图:

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

参考资料

[1]

swagger.io: https://swagger.io/

[2]

springfox: http://springfox.github.io/springfox/

[3]

springfox / springfox: https://github.com/springfox/springfox

[4]

springfox / springfox-demos: https://github.com/springfox/springfox-demos

[5]

Home » io.springfox: https://mvnrepository.com/artifact/io.springfox

[6]

swagger-core: https://github.com/swagger-api/swagger-core

[7]

springfox-swagger: https://github.com/wangzhihaolighter/spring-boot-notes/tree/master/spring-boot-example/E.tools/springfox-swagger

关注Java技术看更多干货

最近有有不少老铁在后台留言说,想进大厂,但是算法不好。最近我整理了一份刷题实录,这份刷题实录,也让我进了心仪的大厂。现在开放分享给大家。希望对大家有所帮助。
任何的算法题,如同写作文一样,都有一些模板可以套用的。比如面试常考的DP(动态规划),难的是一些关键点是否能想清楚。比如你能写出动态转移方程,这题基本上就可以AC了。整个刷题实录内容,包括 双子针、动态规划、二分查找、贪心算法、深度优先搜索、字符串、递归、字典树、排序、链表等相关专题内容。图文并茂,附有刷题答案源码。
刷题任务的题目,是根据题目的类型来汇总的,总结了八个类别,每个类别下面也总结了5个左右的题型,帮助大家分门别类的突破,所以刷起来相对会更有重点和针对性。如果从头到尾的刷,每周按顺序刷42题,很容易让自己坚持不下来,也会觉得很枯燥。所以在制定计划的时候可以让这个计划变得更“有趣"和针对性,让它看起来更容易实现一点,才会更容易坚持。
目前上述内容已打包成完整电子书,具体获取方式如下:扫描关注 Github中文社区公众号;在 Github中文社区 公众号后台回复关键词「刷题」获取下载地址。扫描关注,回复"刷题"即可下载END前线推出学习交流一定要备注:研究/工作方向+地点+学校/公司+昵称(如大数据+上海+上交+卡卡),根据格式备注,可更快被通过且邀请进群扫码加我微信和大佬们零距离历史推荐为什么大公司一定要使用微服务?
微软杀死了曾经全球第一的浏览器
知乎1.3万亿条数据查询毫秒级响应,如何做到的?
为什么程序员都不喜欢使用switch,而是大量的 if……else if ?阿里程序员常用的 15 款开发者工具!
好文点个在看吧!

Swagger 3.0 官方教材出炉,野生的可以扔了!相关推荐

  1. 官方文件出炉!北京住建委权威解读商住限购

    http://finance.sina.com.cn/china/dfjj/2017-03-27/doc-ifycstww1168271.shtml?cre=sinapc&mod=g& ...

  2. 个人信息去标识化指南_重磅解读 | APP收集使用个人信息自评估指南2.0版正式出炉...

    2020年3月19日全国信息安全标准化技术委员会秘书处发布了<网络安全标准实践指南--移动互联网应用程序(APP)收集使用个人信息自评估指南(征求意见稿)>(简称征求意见稿).2020年7 ...

  3. Spring Boot 3.0 新书终于出炉,荣获京东计算机图书排行榜 TOP 1!

    大家好,我是R哥. 我的新书<Spring Boot 3 核心技术与最佳实践>折腾一年多,终于在昨天上市了,太不容易了... 有需要的可以购买学习: 本书定价 158 元,刚上市搞 5 折 ...

  4. 麒麟990怎么转鸿蒙,3个大动作!鸿蒙OS2.0首批体验出炉,麒麟990重获新生

    鸿蒙OS开发版已经面向小部分用户推送了,很多人都关心一个问题:国产手机操作系统的真实体验到底如何,性能真的比安卓系统更强吗? 按照目前的消息来看,鸿蒙OS2.0开发版主要的变化在于UI设计的调整,以及 ...

  5. android6.0升级名单,首批升级Android 6.0机型名单出炉

    今年九月份苹果和谷歌的新品发布会都备受关注,除了新机外iOS 9和Android M(安卓6.0)也同样受到用户关注.近日,谷歌就公开了首批获Android M系统升级的机器名单. 目前,首批升级An ...

  6. 微软Silverlight 3正式版已经出炉

    微软Silverlight 3正式版已经出炉 再过几个小时微软才会官方发布,但Silverlight 3正式版(版本号3.0.40624.0)已经新鲜出炉了.如果你感兴趣可以前往其官方网站升级安装. ...

  7. Silverlight 3正式版新鲜出炉

    [IT168资讯]Silverlight 3正式版(版本号3.0.40624.0)已经新鲜出炉,将于今日正式发布.今日在See the light网站将举行线上发布活动,播放视频Keynote和技术演 ...

  8. 微软学者奖学金2020名单出炉!中国高校八人上榜,清华表现最为亮眼

    微软学者奖学金2020官方名单出炉! 中国高校有八人上榜,其中清华大学表现最为亮眼,有4人入选. 2020 年度的"微软学者"项目吸引了来自全亚洲 36 所顶尖大学及研究机构的 1 ...

  9. 怀化php工资一般多少,【慌了】怀化官方最新平均工资标准出炉,快看看你拖后腿没......

    原标题:[慌了]怀化官方最新平均工资标准出炉,快看看你拖后腿没... NO.5280 ▼ 近日怀化市人力资源和社会保障局和 怀化市统计局发布了 <2016年全市在岗职工平均工资的通知> 据 ...

最新文章

  1. MySql链接字符串 各种程序连接大合集(包括asp.net,c#,等等)
  2. udp 传输文件 java_Java 网络编程 之 UDP 文件传输
  3. mockito mock void方法_Spock如何模拟抽象类方法
  4. sqllite java 密码,SQLite登录检查用户名和密码
  5. 皕杰报表和炎黄盈动(AWS BPM)集成 操作手册
  6. c#利用zlib.net对文件进行deflate流压缩(和java程序压缩生成一样)
  7. SFB 项目经验-35-分配公网证书 For Exchange Server 2016(图解)
  8. 全表行转列——动态SQL
  9. 【定位问题】基于matlab RSSI和模拟退火优化粒子群算法求解无线传感器网络定位问题【含Matlab源码 1766期】
  10. matlab实现卷积操作
  11. 06计算机优秀毕业论文-总结和展望
  12. js,JQ 图片转换base64 base64转换为file对象,blob对象
  13. 于飞SEO:零基础学seo难吗?怎么学?
  14. The artifact org.apache.commons:commons-io:jar:1.3.2 has been relocated to commons-io:commons-io:jar
  15. shell脚本获取cpu、内存、磁盘使用率
  16. 严重性 代码 说明 项目 文件 行 禁止显示状态 警告 CS8032 无法从...创建分析器...的实例: 未能加载文件或程序集...或它的某一个依赖项。系统找不到指定的文件
  17. android gps距离计算器,计算器刷成安卓系统 刷系统千万别找设计师
  18. 快速入门EasyX图形编程
  19. Minecraft 1.12.2模组开发(一) 配置ForgeMDK环境
  20. 实现导入Excel表导入数据库并显示在echarts图形上面

热门文章

  1. 用web audio api 在canvas上画出音频的音轨
  2. Fiddler工具栏(快捷菜单)介绍
  3. isEmpty 和 isBlank 区别?
  4. openwrt php wifi 钓鱼,提高路由器wifi无线速率(OpenWrt固件)
  5. Word键入自动将单双引号修改为弯引号(‘‘或““)
  6. 【仪器使用操作笔记】 TDS1012示波器基础原理与使用
  7. [计算机网络] 运输层 可靠传输rdt 拥塞控制 TCP连接 多路复用
  8. 数据分析技能点-多元分析和应用
  9. LInux last命令详解
  10. WordPress仿114网站导航仿爱导航网站_简约大气网站导航源码网址导航模板源码下载