Spring MVC集成Swagger2.0
在集成Swagger之前,得先说说什么是Swagger,它是用来做什么的,然后再讲讲怎么集成,怎么使用,当然,在这之前,需要了解一下OpenAPI。
OpenAPI 3.0规范定义了一个标准的、语言无关的RESTful APIs,它可以被人和机器所理解和使用,而不需要查找其源码、说明文档或其他方面。如果属性定义正确的话,消费者可以使用少量的逻辑代码与远程服务进行交互。可以使用OpenAPI的接口定义文件生成相应的文档、服务端接口、客户端接口和其他单元测试等等。
简单的来说,就是通过这套规范,先定义接口,再根据定义文件生成相应语言的接口代码,之后可以来进行具体逻辑编写。一次定义,可多次使用。其定义的接口文档主要包含以下内容:
- 可访问的端点(endpoints )和每个端点的操作((
GET /users,POST /users); - 每个端点的输入输出参数;
- 授权方式;
- 联系方式、团队名称、作者等其他信息;
swagger是一个可以帮助你设计、构建代码、生成文档和测试API的工具集合,它是根据OpenAPI的规范具体实现的开源工具。包含以下几个工具:
- Swagger Editor:API设计器,基于浏览器的在线编辑器;
- Swagger UI :根据API的描述信息生成文档,可以查看和测试API;
- Swagger Codegen :根据API的设计文档,生成需要的服务端或客户端代码;
使用它的意义主要在于,接口的规范化开发,文档的快速生成。开发最头疼的就是写文档,这样的话,可以省去大把的时间,而且,这样也利于团队的开发和新人的快速加入,也在系统集成时更加的方便。
废话不多说,开始在Spring MVC中集成Swagger框架。
一、定义API接口文档
我们不具体说明编写过程,使用Swagger提供的样例“宠物商店”(http://petstore.swagger.io/v2/swagger.json)。
二、使用代码生成工具生成Java代码
代码构建工具Codegen(删改你介绍时有Github地址),我们先需要下载构建工具包:
wget http://central.maven.org/maven2/io/swagger/swagger-codegen-cli/2.4.0/swagger-codegen-cli-2.4.0.jar -O swagger-codegen-cli.jar
具体使用方法,可参见其Github项目中的描述。生成代码命令:
java -jar swagger-codegen-cli-2.4..jar generate -i http://petstore.swagger.io/v2/swagger.json -l spring --library spring-mvc -o tmp
参数-l时指语言类型,--library指的是使用的库,spring-mvc、spring-boot或者spring-cloud,默认生成spring-boot的代码。其中的目录截图:

其中的配置目录,

三、引入Swagger的依赖包
复制生成项目中pom的引用即可:
<!--SpringFox dependencies -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>${springfox-version}</version>
<exclusions>
<exclusion>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>${springfox-version}</version>
</dependency>
四、合入代码
将api和model下面的放入对应包结构下,但是configuration中的需要重新配置。因为项目已经配置了MVC,如果直接使用,则会初始化两次mvc的信息,故不使用WebMvcConfiguration和WebApplication两个类。SwaggerUiConfiguration类为配置的入口,里面含有Swagger的配置注解,需要再初始化MVC的时候,加载这个类。SwaggerDocumentationConfig类为Swagger文档的配置类,其中有api的包路径设置,设置正确才能解析出。为了防止启动时候,初始化spring的时候加载这些配置,这些类不能放到基础扫描包里面。再spring-mvc中添加配置想,单独加载SwaggerUiConfiguration类。
五、启动并访问
如看到这些信息,则说明启动成功,可以访问:

访问地址:http://localhost:8080/webapp/swagger-ui.html,效果如下:

六、增加配置项,上线后禁用Swagger-UI功能
spring-mvc.xml中配置如下:
<import resource="classpath*:springfox-${springfox.swagger.mode:default}-swagger.xml"/>
设置VM的启动变量,-Dspringfox.swagger.mode=dev,新增springfox-dev-swagger.xml配置文件,里面加载SwaggerUiConfiguration类。
本文中的代码和配置均已提交Github:https://github.com/FlowerBirds/JavaDemoApp,可以参考。
参考文档:
- https://swagger.io/docs/specification/about/
- https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md
Spring MVC集成Swagger2.0的更多相关文章
- Spring Boot 集成 Swagger2 与配置 OAuth2.0 授权
Spring Boot 集成 Swagger2 很简单,由于接口采用了OAuth2.0 & JWT 协议做了安全验证,使用过程中也遇到了很多小的问题,多次尝试下述配置可以正常使用. Maven ...
- Spring MVC集成slf4j-logback
转自: Spring MVC集成slf4j-logback 1. Spring MVC集成slf4j-log4j 关于slf4j和log4j的相关介绍和用法,网上有很多文章可供参考,但是关于logb ...
- spring mvc集成velocity使用
目前流行的三大页面视图神器是:老牌大哥jsp.后起之秀freemarker和velocity.这里不详细比较这三者的优劣,总体来说,jsp是标配,但后面两个更严格的执行了视图与业务的分离,页面里是不允 ...
- spring mvc 集成freemarker模板
主要使用到的jar 文件:spring mvc +freemarker.jar 第一步:spring mvc 集成 freemarker <!-- 定义跳转的文件的前后缀 ,视图模式配置--&g ...
- spring mvc集成freemarker使用
freemarker作为视图技术出现的比velocity早,想当年struts风靡一时,freemarker作为视图层也风光了一把.但现在velocity作为后起之秀的轻量级模板引擎,更容易得到青睐. ...
- Spring MVC集成Swagger
什么是Swagger? 大部分 Web 应用程序都支持 RESTful API,但不同于 SOAP API——REST API 依赖于 HTTP 方法,缺少与 Web 服务描述语言(Web Servi ...
- Spring boot集成swagger2
一.Swagger2是什么? Swagger 是一款RESTFUL接口的文档在线自动生成+功能测试功能软件. Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格 ...
- Spring MVC集成Log4j
以下示例显示如何使用Spring Web MVC框架集成LOG4J.首先使用Eclipse IDE,并按照以下步骤使用Spring Web Framework开发基于动态表单的Web应用程序: 创建一 ...
- Spring Boot 集成Swagger2生成RESTful API文档
Swagger2可以在写代码的同时生成对应的RESTful API文档,方便开发人员参考,另外Swagger2也提供了强大的页面测试功能来调试每个RESTful API. 使用Spring Boot可 ...
随机推荐
- mac StarUML3.0.2破解
mac StarUML3.0.2破解 StarUML是一款开放源码的UML开发工具,是由韩国公司主导开发出来的产品,可以直接到StarUML网站下载.可以用来创建UML类图. 破解办法是通过asar工 ...
- redis windows相关操作笔记
设置远程访问 1.注释掉bind 127.0.0.1. 2.protected-mode属性从yes改为no. 启动redis服务:redis-server.exe redis.windows.con ...
- Linux基础命令练习题(附答案)
1.分别用cat \tac\nl三个命令查看文件/etc/ssh/sshd_config文件中的内容,并用自己的话总计出这三个文档操作命令的不同之处? [root@localhost ~]# cat ...
- Librepilot-Spark2固件的烧写
1.通过USB连接Librepilot_Spark2飞控,启动Librepilot GCS地面站(博主的GCS是16.09版本),界面如下. 2.点击Firmware标签页,点击终止系统(若板子未带系 ...
- 在VMware Vcenter添加一块网卡后,启动虚机找不到网卡,发现有一个ens38(redhat7.5)
添加一块网卡后,启动虚机找不到网卡,发现有一个ens38 问题:新建虚拟机设置为一块网卡,时候在Vcenter再添加一块网卡,这个问题相信很多网友都见过,今天就来总结一下添加过程中的问题. 由于有以前 ...
- jmeter之HTTP信息管理器、正则表达式联合使用(获取登录session
如图所示,信息管理头的信息为请求头信息,如图所示 注意事项:1)body date里面的参数要是要注意英文编写条件下,可以通过https://www.json.cn/在线的json格式刷格式 2)注意 ...
- 单调队列优化DP || [NOI2005]瑰丽华尔兹 || BZOJ 1499 || Luogu P2254
题外话:题目极好,做题体验极差 题面:[NOI2005]瑰丽华尔兹 题解: F[t][i][j]表示第t时刻钢琴位于(i,j)时的最大路程F[t][i][j]=max(F[t-1][i][j],F[t ...
- 【NOIP2016提高A组模拟9.9】爬山
题目 国家一级爬山运动员h10今天获得了一张有着密密麻麻标记的地图,在好奇心的驱使下,他又踏上了去爬山的路. 对于爬山,h10有一个原则,那就是不走回头路,于是他把地图上的所有边都标记成了有向边.他决 ...
- 阿里云服务器 CentOS 7.5 64位 docker安装redis集群
网上有很多教程可以参考,但是遇到坑了...... 最后参考这个教程成功了.https://www.cnblogs.com/hbbbs/articles/10028771.html 安装docker 参 ...
- html aside标签 语法
html aside标签 语法 aside是什么意思? aside为语义化标签,通常用来描述与文档主体内容不相关的内容,其aside标签的内容应该与附近的内容相关. 作用:定义其所处内容之外的内容.直 ...