Swagger2 与 springmvc 集成实现API文档化

2024-03-14 15:32

本文主要是介绍Swagger2 与 springmvc 集成实现API文档化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么要实现API文档化?

  1. API文档化有利于前后端分离的开展。随着开发方式全面转成前后端分离,前端和后端的唯一沟通就在API层面。在没有文档化之前,开发人员只能口头的交代并反复理解每个接口参数和返回值,这个过程相当不稳定,变化频繁。而通过API文档化后,可以通过文档的清晰定义,使得前后端人员减少无畏沟通,并在理解上保持一致;

  2. API文档化有利于接口自动化测试。公司马上上马接口自动化测试,对接口参数和返回值要通过Json方式导入自动化测试程序。而用特殊工具生成的API文档,可以直接输出json格式的文档,简化了测试流程,减轻了开发人员的工作量;

  3. API文档化有利于系统文档建设。开发人员不愿意写文档,写注释。而为了以上两个目的必须要求开发人员在编码的同时补充相关的API描述,而通过一个相对稳定成熟和趁手的工具可以大大减轻文档的工作量,做到事半功倍。

Swagger和spring-boot-starter-swagger

Swagger是业界比较流行的实现API文档化的工具。优点有

  1. 通过在项目中引入Swagger,可以使用简单的Annotation,就实现了API文档化;
  2. Swagger提供标准的json或yaml文档,方便做进一步解析,典型应用是接口自动化测试;
  3. 页面可以直接进行测试(try-it-out功能,部分替代Postman);
  4. Swagger还提供类似于github的SwaggerHub,相当于公共的API文档集散地。

Swagger的项目主页:https://swagger.io/


搭建和使用 可以参考以下网址:

微服务之Swagger :https://www.cnblogs.com/softidea/p/6251249.html 


SpringBoot学习笔记之集成swagger : http://blog.csdn.net/liyuejin/article/details/78036582


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

springfox &Swagger2的API

http://springfox.github.io/springfox/docs/current/#springfox-spring-mvc-and-spring-boot


这篇关于Swagger2 与 springmvc 集成实现API文档化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/808853

相关文章

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI