比较Java REST文档框架

确定在记录REST API时选择哪种Java框架可能很麻烦。 在本博文中,我们将简要比较我们自己使用的REST Web服务的三种文档框架,以及它们如何与Spring框架(这是Foreach最常使用的Java框架)集成。 这些是RESTful API建模语言(RAML),Swagger UI和Spring REST Docs。

在每一部分中,我们将对所讨论的文档框架进行高层概述。 我们将简要描述文档框架如何与Spring集成以及如何在您的文档中使用该框架影响构建周期。

RESTful API建模语言(RAML)

Java框架

RAML是一个单独的文档,与您作为开发人员需要手动维护的项目一起保存。 在默认的RAML配置中,几乎不会自动执行任何操作。 但是,借助随附的插件生态系统,很容易扩展RAML使其表现出所需的行为。

该文档框架的生态系统非常活跃,其插件启用了各种功能,例如:

  • API Workbench :“一个用于设计,构建,测试,记录和共享RESTful HTTP API的丰富,功能齐全的集成开发环境(IDE)”;
  • RAML Java客户端生成器 :根据RAML文档自动生成Java客户端的工具;
  • RAML2HTML :一种Node.js工具,用于生成用户友好HTML文档。

在构建过程中定义的额外步骤中,书面文档将从RAML格式转换为人类可读的文本(或HTML)。

过去,RAML曾经是Java中我们首选的文档框架,但是现在我们发现了一些替代方案,因此开始越来越少地使用RAML。 另外,使用RAML很难编写也易于使用的完整文档(因为RAML中的所有文档都需要手动编写)。 此外,我们通常会在对API进行调整后忘记更新文档。 通过使用一个框架可以解决此问题,在该框架中,大多数API更改都是自动记录的,而不是手动记录的。

招摇UI

相反,Swagger UI会自动生成所有内容。 在此框架中,Swagger与Swagger UI和Springfox协同工作以在运行时生成文档。 该框架包含三个组件:

Java框架
  • Swagger是规范的一部分:一组描述RESTful服务的规则(与RAML相当);
  • Swagger UI是呈现部分:它呈现用户友好HTML(就像RAML2HTML一样),并允许用户在没有任何客户端基础结构的情况下测试服务,因为它会基于Swagger服务规范自动生成测试客户端;
  • Springfox是“生成”部分:它与服务交互(通过注释,包括它自己的注释和Spring注释),以在运行时自动生成文档。

这三个组件将检查您的代码以确定需要记录的内容。 他们既可以生成文档(通过动态网站),也可以通过Swagger UI进行“测试服务调用”。 服务调用的工作方式与例如Postman相同,唯一的区别在于,该库可以通过从应用程序的文档化部分向服务发送原始请求来在浏览器中工作。

由于Springfox将在运行时负责生成,因此无需定义额外的构建步骤(与RAML和Spring REST Docs不同,在其中需要单独的构建步骤)。

当我们第一次开始使用它时,Swagger堆栈似乎很棒。 我们几乎没有(人工)劳动,因为一切都是自动生成的。 同时,我们仍然可以通过在代码中添加注释来调整文档。 我们认为,这既是优点也是缺点。 因为虽然Swagger UI确实易于使用,但是我们对生成的文档的控制没有我们想要的那么多。

Spring REST文件

Spring REST Docs是Spring生态圈的一部分,可根据您的单元测试生成AsciiDoc片段。 这些片段可以包含在手写的AsciiDoc中,以为您的API汇编文档。

Java框架

为此,您可以指定希望从对MockMVC端点的调用中检索的字段,并定义要在文件系统上创建生成的代码段的位置。 如果期望的字段与结果不完全一致,则您的测试将失败,这意味着与文档相关的单元测试也将作为代码的额外检查。

在构建过程的后期,您将需要定义一个额外的步骤,通过将生成的代码片段与手写索引页结合起来,生成人类可读HTML文件,从而促进文档的传播。

我们在一个项目中使用了Spring REST Docs,该项目需要外部参与者使用API​​和常规文档。 他们使用自己的测试工具,因此不希望为他们提供基于浏览器的界面来测试该界面。 我们之所以选择REST Docs框架,是因为(a)它也可以成为我们集成测试的一部分,并且(b)我们可以轻松地将其与所有其他非技术性文档结合在一起。

总览

Java框架

如您所见,“最佳”文档框架取决于您期望文档框架能够完成的工作。 如果您希望不需要大量的“静态”文档(即,如果可以自动生成所有内容),则开箱即用即可轻松使用Swagger UI。

另一方面,如果您需要提供单个文档,或者只想对文档进行更多控制,则最好使用RAML或Spring REST Docs之类。 而且,已经证明与Spring REST Docs中的测试集成非常有用。

无论您选择什么,每个单独的框架都足以以明确的方式将Web服务的合同传达给其他开发人员-这最终是这些框架的目标。

翻译自: https://www.javacodegeeks.com/2019/01/comparing-java-documentation-frameworks.html

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

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

相关文章

jaVa游戏三国志英杰传,《三国志英杰传》到底是怎样的一款游戏

原标题:《三国志英杰传》到底是怎样的一款游戏介绍作为PC平台上经典的战棋策略类游戏,英杰传系列可谓把这一类型游戏在战略性和资源获取上的精髓发挥的淋漓尽致。系列初代的《三国志英杰传》诞生在1995年的DOS系统上,虽然我接触英杰传时已经是…

jvm 内存镜像_镜像镜像–使用反射在运行时查看JVM内部

jvm 内存镜像开发人员:Takipi会告诉您何时新代码在生产中中断– 了解更多 我们都习惯于在我们的日常工作中直接或通过利用反射的框架来运用反射。 它是Java和Scala编程的主要方面,它使我们使用的库可以与我们的代码进行交互,而无需对其进行硬…

谁去过顽皮,谁去过尼斯? 圣诞老人为您提供Java 11建议!

有没有想过圣诞老人如何为世界各地的孩子们送上节日礼物? 有20亿个孩子,每个孩子都有自己的愿望清单,他会在24小时内完成。 这意味着每个孩子平均需要43微秒,他需要检查每个孩子是否顽皮或好。 您无需再怀疑了。 我会透露这个秘密…

php时间格式函数,PHP函数之日期时间函数date()使用详解_php基础_脚本

$ttime();echo date("Y-m-d H:i:s",$t);第一个参数的格式分别表示:a - "am" 或是 "pm"A - "AM" 或是 "PM"d - 几日,二位数字,若不足二位则前面补零; 如: "01" 至 "31"D - 星期几…

play框架配置 拦截器_如何使用Play框架为https配置SSL证书

play框架配置 拦截器我花了几个小时试图使它起作用,最后,问题是我自己没有使用keytool生成CSR(证书请求)。 当我尝试通过https访问Play时,我一直收到此错误: javax.net.ssl.SSLPeerUnverifiedException&a…

matlab 球坐标绘图,MATLAB绘制地图

1使用向量绘制地图1.1绘制全球海岸线向量数据可以表示一个地图。这种向量存在的形式是一系列的经纬度或投影坐标对,它们代表一个点集、一个线条或者多边形。例如,描绘出行政区域边界的点、公路系统、城市的中心或者以上三个集合放在一起,都可…

php 有 stringbuffer,String、StringBuffer、StringBulider三者介绍

三者都实现了CharSequence接口,因此CharSequence可认为是一个字符串的协议接口1.String类是不可变类,即一旦一个String对象被创建后,包含在这个对象中的字符序列是不可改变的,直至这个对象被销毁;我们常常定义的时候 S…

php生成网页按钮,JavaScript实现自动生成网页元素功能(按钮、文本等)_javascript技巧...

创建元素的方法:1、利用createTextNode()创建一个文本对象2、利用createElement()创建一个标签对象3、直接利用容器标签中的一个属性:innerHTML-----本质上改该标签容器中的“html代码”,不是我们认为的对象树的操作详解代码:这是…

adf 自动输稿器_在ADF实体PK属性中使用MySQL自动增量PK列

adf 自动输稿器大家好。 继续进行ADF MySQL解决方法系列,今天我们将看到需要做些什么才能将MySQL PK自动增量列与ADF实体PK属性一起使用。 如果使用的是Oracle数据库,则可以使用oracle.jbo.domain.DBSequence以及序列和触发器来立即进行操作。 为简单起…

探索适用于Apache Spark的Spline Data Tracker和可视化工具(第1部分)

最近引起我注意的一个有趣且充满希望的开源项目是Spline ,它是由Absa维护的Apache Spark的数据沿袭跟踪和可视化工具。 该项目由两部分组成:一个在驱动程序上工作的Scala库,该驱动程序通过分析Spark执行计划来捕获数据沿袭,并提供…

高性能mysql 聚簇索引,高性能MySQL笔记-第5章Indexing for High Performance-005聚集索引...

一、聚集索引介绍1.什么是聚集索引?InnoDB’s clustered indexes actually store a B-Tree index and the rows together in the same structure.2.为什么一张表只能一个聚集索引?When a table has a clustered index, its rows are actually stored in …

PHP应用GD2函数填充几何图形,使用GD2函数绘制几何图形(PHP图形图像的典型应用教程4)...

使用GD2函数绘制几何图形(PHP图形图像的典型应用教程4)本篇主要讲解使用GD2函数实现几何图形的绘制,首先我们需要的事创建一个图像,在之前的文章中我们就说过了,创建图像是所有图像操作的第一步,然后再背景上根据坐标点绘制图形轮…

API测试和自动化101:基本指南

API代表A pplication P AGC软件我覆盖整个院落。 通常,API用于通过使用任何通信方式来促进两个不同应用程序之间的交互。 在网络上使用API​​时,我们将其称为“ Web服务”。 最近,API已成为编程的Struts。 与在应用程序中一样,编…

oracle数据库安装HotSpot,安装Oracle数据库软件遭遇诡异的HotSpot Virtual Machine Error : 11报错...

虽然也装了很多次的数据库了,可是偶尔还是会碰见一些很无语的错误,前两天在RHEL5.0上安装Oracle 10g 10.2.0.1,起图形后点击下虽然也装了很多次的数据库了,可是偶尔还是会碰见一些很无语的错误,前两天在RHEL5.0上安装O…

linux结束所有任务命令行,Linux基础命令(15)定时任务

释放双眼,带上耳机,听听看~!crontadLinux定时任务Crontab命令详解linux 系统则是由 cron (crond) 这个系统服务来控制的。Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的。另 外, 由于使用者自己也可以设…

如何修复无效的目标版本:Maven Build中的1.7、1.8、1.9或1.10错误

如果您正在使用Maven构建Java项目,可能是在Eclipse中,或者是通过运行mvn install在命令提示符下构建的,并且构建失败并显示诸如“无效的目标发行版:1.7”或“无效的目标发行版:1.8”之类的错误,那么您来了到…

Linux查看时间段文件,Linux查看特定时间段内修改过的文件

一.Linux系统日志的一些信息,日志配置文件syslog.conf系统日志一般都存在/var/log下常用的系统日志如下:核心启动日志:/var/log/dmesg系统报错日志:/var/log/messages邮件系统日志:/var/log/maillogFTP系统日志:/var/log/xferlog安全信息和系统登录与网络连接的信息…

使用ClickHouse UDF与OpenAI模型集成

本文字数:14683;估计阅读时间:37 分钟 作者:Dale McDiarmid 审校:庄晓东(魏庄) 本文在公众号【ClickHouseInc】首发 Meetup活动 ClickHouse Shenzhen User Group第1届 Meetup 火热报名中&#x…

使用Spring Boot和Vue.js构建一个简单的CRUD应用

“我喜欢编写身份验证和授权代码。” 〜从来没有Java开发人员。 厌倦了一次又一次地建立相同的登录屏幕? 尝试使用Okta API进行托管身份验证,授权和多因素身份验证。 在本教程中,您将使用Vue.js作为客户端并将Spring Boot作为资源服务器来构…

linux安装 icc编译器,安装 Intel Compiler (ifort icc icpc)

在下载目录下解压heqinheqin-dell:~/Downloads$ tar zxvf parallel_studio_xe_2017_update7.tgz进入解压后的文件夹heqinheqin-dell:~/Downloads$ cd parallel_studio_xe_2017_update7/为了记录过程而不用截图,我选择用命令行安装,当然你也可以用install…