接口文档神器Swagger(下篇)

本文来自网易云社区


作者:李哲

二、Swagger-springmvc原理解析

上面介绍了如何将springmvc和springboot与swagger结合,通过简单配置生成接口文档,以及介绍了swagger提供的一些注解。下面将介绍swagger是如何做到与springmvc结合,自动生成接口文档。

项目添加完成maven依赖后会加入swagger的依赖包,其中包括swagger- springmvc,swagger-annotations,swagger-models几个依赖包。如下图所示:

201809040948400e03308a-a090-4e3a-bc63-a4193865b4d0.jpg


其中,swagger-annotations是swagger提供给spring的注解包,上面说的注解基本都在这个包里面;swagger-models是swagger自己的model类,主要用于将注解解析成后面需要使用的model和一些model数据的处理。Swagger-springmvc是swagger接入spring的一个最重要的包,通过这个包的处理可以将添加的注解信息解析出来,自动生成接口需要的数据,最后通过url请求就能返回接口的信息,通过前端处理就可以在页面上看到接口的信息。下面将重点分析swagger-springmvc包下的文件,本文中分析的是1.0.2版本的swagger-springmvc,其他版本会存在差异,请自行研究。

下图是swagger-springmvc包结构,图中标红的两个类是swagger的入口类,根据包的名字大致能猜出各个模块的功能。这里先简单介绍下,annotation包下只有一个注解类ApiIgnore,用于忽略不被swagger处理;authorization包下主要用于处理需要认证的接口,添加认证信息;configuration主要处理配置相关的操作,其中包含了程序的配置SpringSwaggerConfig类,该类是swagger的默认配置类,也可以自己编写封装去修改配置(一般都会编写自己的配置类,设置一些api信息等)。Controller用于处理请求swagger文档时返回数据给前端ui;core是整个处理过程的核心模块,例如注解的解析,model的处理,一些处理过程中的策略等等;ordering包中是用于处理页面显示接口时,一些排序问题,其中的class都继承了Ordering<T>类,实现了Comparator<T>接口;paths包下了类主要是处理前端访问swagger接口时的路径问题;plugin是swagger和spring结合的适配处理,也是程序的入口,相对spring来说,swagger就像一个插件接入spring中;scanners和readers两个包主要是处理注解的获取和扫描解析。swagger- springmvc包下的大致结构就是这样的,看到这是不是觉得swagger没那么神奇了,其实swagger做的两件最主要的事就是:扫描解析注解变成相应的model,前端请求接口文档时返回后台处理好的接口信息。

2018090409485306e3b7a1-b215-47f8-a8cd-bb4a5a1401e3.jpg

马上就要进入程序入口了,是不是有点激动呢?可能有的人会问,怎么知道Swagger PluginAdapter是程序的入口?配置的文件不是SpringSwaggerConfig吗?进入源代码就能找到答案,下面来看下SwaggerPluginAdapter类:

201809040949083fd3cfb2-0a44-460c-9226-3dea852f887b.jpg

这个类实现了ApplicationListener<ContextRefreshedEvent>接口,这是一个spring的接口,在spring的applicationcontext初始化完成后会执行onApplicationEvent方法,所以当spring启动后,swagger就会被启动。而SpringSwaggerConfig中使用了注解@configuration,会在spring启动时进行swagger配置,在配置的时候会根据用户自定义的配置进行设置,如果用户没有定义将用默认的配置。下面看下方法onApplicationEvent中的处理,如下图所示,程序会先去判断plugins是否存在,不存在直接使用默认的,如果配置中设置了plugin则使用配置中的SwaggerSpringMvcPlugin,最后都调用Swagger SpringMvcPlugin类的initialize方法。

20180904094921fcb61965-74a0-42cf-b019-5da4e93490e6.jpg


SwaggerSpringMvcPlugin是swagger和spring框架核心的类。有好多可配置的属性,并且提供了相应的get与set方法。 在该类中,初始化了SwaggerApiResourceListing类(用于扫描RequestMappingHandler方法)的属性。 当调用initialize()方法的时候,调用的则是SwaggerApiResourceListing类的initialize()方法。

20180904094937b6fd94e5-1a88-4efe-81a9-d6ccc80678a0.jpg

在initialize方法中主要做了两件重要的事,第一通过apiListingReferenceScanner扫描所有的spring请求路径(RequestMapping),过滤没在配置类中设置的include Patterns,将扫描结果转换为swagger自定义的model中。第二通过apiListingScanner类扫描第一步处理的每一个请求路径,根据swagger的注解扫描每一个路径对应的接口信息,最后将信息转换为swagger中model并保存在swaggerCache中方便以后使用。

接下来分析具体的扫描过程,ApiListingReferenceScanner中的scan方法是调用该类中的scanSpringRequestMappings方法。在该方法中主要做的是根据spring中的Request MappingHandlerMapping找出符合条件的路径并找出一些需要的信息保存起来。

20180904094955ef8c4b18-1d61-4d29-af73-d0bc2592a7fb.jpg

ApiListingScanner类中主要扫描每个请求路径的具体接口信息,具体的扫描过程是通过命令模式执行。代码中的每一种reader对应一种具体要执行的命令操作,对所有的请求路径(RequestMapping)分别获取MediaType、接口描述、接口model等信息。其中,MediaTypeReader是解析请求的MediaType类型,ApiDescriptionReader是解析接口的信息,ApiModelReader是解析接口的model(即ApiModel标注的类)。解析完成后分别将这些信息保存起来。ApiDescriptionReader中主要处理了请求路径,然后通过ApiOperationReader去处理真正的接口信息。execute方法中可以看到分别去处理写在接口上的注解。

20180904095008485c6921-9192-4c2c-b3f1-2e1f79e4a3d0.jpg


下面以一个OperationImplicitParametersReader为例介绍各种Reader是如何通过命令模式去处理对应的注解,其中通过AnnotationUtils.findAnnotation方法去查询Api ImplicitParams注解去获取接口上标注的参数信息,然后在继承类SwaggerParameterReader中的execute方法中被调用。


20180904095023bc2e54e6-ec9b-4b97-b006-116b285c3ce1.jpg  


2018090409504835867ee9-5543-4e88-bd9b-a0997391d35a.jpg

其他的注解也是通过这种方式被读取出来,最后会将这些信息保存到SwaggerCache中,到此swagger处理代码中的注解就已完成,当然过程中还有处理一些其他信息,例如,需要登录认证的信息,处理接口的请求路径以方便swagger本身请求接口时应用等等。但是这些处理好的信息是怎么能在前端页面显示的呢?接下来就研究下swagger如何在前端显示接口信息。在swagger的默认配置类中有个ComponentScan注解标注需要扫描的包com.mangofactory.swagger.controllers,在该包下有一个controller叫DefaultSwaggerController,代码如下:

20180904095106ccbcd4d0-ce63-41f6-ae9d-3e8cf78e2229.jpg

可以看到,swagger根据处理好的路径对应返回相应的接口信息,从这里可以看到为什么解析的数据都放到SwaggerCache中,这样后台controller就可以返回请求的接口数据,通过前端页面的解析就能在前端显示接口的信息。下图是前端代码结构,通过index.html访问接口信息。

20180904095121ddb9339e-0991-48f3-9b84-d4e73eb65c3a.jpg


至此swagger-springmvc是如何做到通过简单注解配置就能实现自动生成接口文档信息的原理就讲完了,具体细节处理有兴趣者可以自己研究。现在看来swagger也没这么神奇了,但是其中用到的方法是值得我们学习使用的。例如,如何通过spring的方式获取spring中管理的一些资源,命令模式,结合spring的插件开发等等。

三、Swagger其他功能

除了上面介绍的功能外,swagger还有一些其他功能,打开swagger的官网

https://swagger.io/可以看到除了介绍的功能,还有一些其他工具。

20180904095135bdf04fb3-6b0d-433b-8ffb-f4dc60586c7b.jpg


这里简单介绍下swagger包含的其他功能,SwaggerEditor是一个swagger文档编辑工具,通过该工具可以实现静态接口文档编写,而且可以查看实时接口信息,上面一排按钮可以实现保存,生成相关代码等功能。如下图所示:

20180904095146f837b359-1f72-4aa1-b639-900d5a658eb2.jpg

SwaggerCodeGen是一个代码生成的工具,即通过该工具可以实现根据接口信息生成各种语言的接口代码,可以生产前端、后台、移动端代码框架,可以通过 swagger- codegen-cli脚手架工具或者访问github地址:https://github.com/swagger-api/swagger- codegen根据提示操作,里面也有示例。生成前端、移动端的代码根据各语言通用的框架实现接口请求,例如android的代码中使用okhttp请求接口数据;同时可以通过静态接口文档生成服务器端代码,这样会根据文档中定义的接口信息和model生成相应的model和controller接口。通过SwaggerCodeGen生成的代码在大型项目中可能不太实用,因为里面很多代码不符合人们编码习惯,但是在快速开发的小型项目中可以尝试使用。

Swagger UI是展示接口页面的前端框架,接口信息就是通过这个框架显示出来的,所以不管是静态接口文档还是通过后台代码生成的接口信息都可以通过SwaggerUI来显示。上面介绍的swagger结合springmvc使用中使用的就是Swagger UI来显示接口页面。下图是swagger官网上的一个示例:

201809040952005d94382b-c961-4152-b4d2-0152c850b861.jpg


Swagger Inspector是一个测试接口工具,类似postman,主要用来测试请求返回情况,可以通过在线Swagger Inspector测试接口,基本测试是免费使用的。swagger还提供了一些高级功能,如安全扫描、复杂功能测试、load测试及监控数据等,可以根据需求付费使用。如下图所示,Swagger Inspector也可以保存请求历史,可以选择请求生成swagger文档。

201809040952138ddfc1af-e1a8-49a6-ad9a-bf3ccf3074d7.jpg


除此之外,swagger还提供了SwaggerHub,这是一个swagger仓库,可以将文档上传保存,同时支持团队协作,在线编辑,安全线上查阅等功能。Swagger还提供很多开源项目和活跃的社区,如果遇到问题可以去寻求帮助。

四、总结

本文主要介绍了swagger的简介,如何在springmvc和springboot中使用swagger,swagger是如何在springmvc中发挥神奇功效的以及swagger的其他功能等。但是swagger也存在一些问题,例如需要在后台代码中加一些注解,过多的注解造成注解泛滥;接口文档需要等到后台接口写好才能在前端展示,而一般开发可能需要先定义好接口,然后才开始写代码造成的流程混乱;要很深入的了解swagger需要时间和精力,对于忙业务的开发可能觉得不值得在上面花时间学习。其实对于这些问题都有很好的办法解决,相比通过简单学习就能方便的获得接口信息而且不用反复更新文档是很值得的一件事。对于接口文档需要等后台开发完才能展示的问题,可以先通过静态的文档书写方式先写文档,之后再通过后台接口方式实现。

通过上面的介绍,我们了解到swagger是一个功能非常强大的工具,如果能很好地利用这个工具将很大程度上提高我们的开发效率。虽然swagger之前也被爆出安全性问题,但这个问题在后续版本中得到了修复,所以赶快学习使用这个神器。由于时间仓促,如果文中有错误请谅解。

附(常用注解表):

201809040952273951845e-58c3-4b9e-8472-a1b50d338375.png



相关阅读:接口文档神器Swagger(上篇)

网易云大礼包:https://www.163yun.com/gift

本文来自网易云社区,经作者李哲授权发布


 


相关文章:
【推荐】 用SolrJ操作Solr做搜索(上篇)
【推荐】 【专家坐堂】四种并发编程模型简介
【推荐】 视觉设计师的进化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/282241.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用python进行数据分析D1——ch02引言

基础的课程还没学完&#xff0c;就来这本了&#xff0c;因为我平时的研究还是以数据的处理为主。把自己的事做好做细致读了一下介绍部分&#xff0c;下载书里用到的数据&#xff0c;下载地址&#xff1a;https://github.com/wesm/pydata-book 如果你需要完成以下几大类任务&…

记一次Memory Leak分析

起因&#xff1a;最近公司的一个web产品遇到了内存溢出&#xff0c;于是开始着手调查。调查&#xff1a;首先当务之急是找到那个或那些API导致Memory Leak&#xff0c;这个应该不难&#xff0c;根据监控分析&#xff0c;在内存上升时间段内有哪些API被访问&#xff0c;再就是根…

WebSocket教程

一、为什么需要 WebSocket&#xff1f; 初次接触 WebSocket 的人&#xff0c;都会问同样的问题&#xff1a;我们已经有了 HTTP 协议&#xff0c;为什么还需要另一个协议&#xff1f;它能带来什么好处&#xff1f; 答案很简单&#xff0c;因为 HTTP 协议有一个缺陷&#xff1a…

C# WPF十个美观的界面设计展示

概述很多时候&#xff0c;我们设计的界面总是感觉缺乏美感&#xff0c;不是我们不会开发好看的界面&#xff0c;而是不知道怎么才算美观&#xff0c;这时候我们不妨看看别人好的页面是怎么做的.下面展示一些我觉得做的比较好的cs界面&#xff0c;希望能给大家在平时做界面设计时…

MySQL5.6二进制软件包编译安装详解(三)

一、软件环境 [rootlocalhost ~]# uname -r 3.10.0-862.el7.x86_64 [rootlocalhost ~]# cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core) 二、安装部署过程详解 MySQL安装3种方式&#xff1a;1>rpm包安装应用文件默认安装在/usr/local 目录下2>源码编译需…

使用autok3s 安装k3s 集群 和 kuboard 管理集群

一、k3s介绍1.1 什么是k3s?k3s 是经过 CNCF 认证的由 Rancher 公司开发维护的一个轻量级的 Kubernetes 发行版&#xff0c;内核机制还是和 k8s 一样&#xff0c;但是剔除了很多外部依赖以及 K8s 的 alpha、beta 特性&#xff0c;同时改变了部署方式和运行方式&#xff0c;目的…

社区纠纷不断:程序员何苦为难程序员

出品 | OSC开源社区&#xff08;ID&#xff1a;oschina2013)今年年初&#xff0c;我们报道“因为被多人侮辱大吼&#xff0c;Swift 之父正式退出 Swift 核心团队”。诸如此类的“语言暴力”、“网络暴力”事件在开源社区乃至整个 IT 社区屡见不鲜。多个技术社区&#xff0c;都出…

PHP 分布式集群中session共享问题以及session有效期的设置

一、Session的原理 以下以默认情况举例&#xff1a; session_start();之后&#xff0c;会生成一个唯一的session_id&#xff0c;每一个用户对应唯一一个session_id&#xff0c;每一个session_id对应服务器端的一个session文件。这个session文件存储着当前session_id的信息&am…

[SDOI2009]Bill的挑战——全网唯一 一篇容斥题解

全网唯一一篇容斥题解 Description Solution 看到这个题&#xff0c;大部分人想的是状压dp 但是我是个蒟蒻没想到&#xff0c;就用容斥切掉了。 并且复杂度比一般状压低&#xff0c; &#xff08;其实这个容斥的算法&#xff0c;提出来源于ywy_c_asm&#xff09; &#xff08;然…

对象存储OSS服务

一、oss是什么 阿里云对象存储服务&#xff08;Object Storage Service&#xff0c;简称OSS&#xff09;为您提供基于网络的数据存取服务。使用OSS&#xff0c;您可以通过网络随时存储和调用包括文本、图片、音频和视频等在内的各种非结构化数据文件。 阿里云OSS将数据文件以…

《Access 2007开发指南(修订版)》一一1.5 什么是数据库对象

本节书摘来自异步社区出版社《Access 2007开发指南(修订版)》一书中的第1章&#xff0c;第1.5节&#xff0c;作者&#xff1a; 【美】Alison Balter&#xff0c;更多章节内容可以访问云栖社区“异步社区”公众号查看。 1.5 什么是数据库对象 Access 2007开发指南(修订版)正如前…

ETL工具kettle的组件--生成记录

今天介绍下kettle的一个比较实用的组件——生成记录&#xff1b;当我们想将一部分文本数据变成数据行&#xff0c;每个字段作为一个数据行的一个列&#xff0c;那么我们可以利用这个组件&#xff1b;它的位置在双击点开根据自己的实际需要进行设置当设置后&#xff0c;可以点击…

Linux学习笔记一

linux  kernel lib module shell tools ls -la&#xff1a; 显示所有文件包括隐藏文件  cat /proc/cpuinfo&#xff1a; 显示cpu信息 man man  /string&#xff1a; 向上搜索string字符串 继续按下小写n向上搜索  ?string&#xff1a; 向下搜索string字符串 继续按下大…

PHP中路由和rewrite的使用

一、场景介绍&#xff1a; 1、简化url地址&#xff0c;方便大家记忆 2、有利于搜索引擎优化 3、安全&#xff08;让用户看不出网站的目录结构&#xff09; 举例&#xff1a;比如我这里将main控制器中的bb方法路由到kk&#xff0c;这样&#xff0c;我们a标签请求跳转到cp.xi…

《NoSQL权威指南》导读

引言 NoSQL权威指南“没有什么会比引入新秩序更难&#xff0c;因为创新者必须要面对那些在旧环境中已经做得很好的对手&#xff0c;以及那些在新环境中做得很好的冷漠者。” ——Niccolo Machiavelli [1] 在过去的几十年&#xff0c;我已经通过Elsevier/Morgan Kaufmann出版社出…

PHP开发常见功能实现流程

一、pc端网站登录 1、获取并过滤用户提交的用户名和密码以及验证码 2、验证用户提交验证码和session中的验证码是否一致 3、验证用户名是否存在 4、根据用户名获取密码&#xff0c;并校验密码是否一致 5、密码一致&#xff0c;则登录成功&#xff0c;跳转到对应的首页 图示…

七牛直播云服务技术揭秘

以下根据七牛云首席布道师何李石现场演讲内容整理。 直播模型及其实现 一个通用的直播模型一般包括三个模块&#xff1a;主播方、服务器端和播放端。 首先是主播方&#xff0c;它是产生视频流的源头&#xff0c;由一系列流程组成&#xff1a; 第一&#xff0c;通过一定的设备来…

golang 标准库间依赖的可视化展示

简介 国庆看完 << Go 语言圣经 >>,总想做点什么,来加深下印象.以可视化的方式展示 golang 标准库之间的依赖,可能是一个比较好的切入点.做之前,简单搜了下相关的内容,网上也要讨论,但是没有发现直接能拿过来用的.标准库之间,是必然存在依赖关系的,不同库被依赖的程…

《HTML5 2D游戏编程核心技术》——第1章,第1.3节特别功能

本节书摘来自华章出版社《HTML5 2D游戏编程核心技术》一书中的第1章&#xff0c;第1.3节特别功能&#xff0c;作者&#xff3b;美&#xff3d; 戴维吉尔里&#xff0c;更多章节内容可以访问云栖社区“华章计算机”公众号查看。 1.3 特别功能 Snail Bait游戏有3个特别的功能&a…

XunSearch的安装和加入服务器开机脚本以及将目录写入系统变量

一、安装xunserach 1、cd ~ 2、wget http://www.xunsearch.com/download/xunsearch-full-latest.tar.bz2 #下载最新xunsearch包 3、tar -xjf xunsearch-full-latest.tar.bz2 #解压xunsearch包 4、cd xunsearch-full-1.4.11/ #进入xunsearch包目录 5、sh setup.sh #执…