Java / Spring:如何快速生成整个Swagger记录的CRUD REST API

作为开发人员,我们在日常生活中经常面临的最繁琐的任务之一就是编写良好且易于理解的文档。 无论我们的文档只有几行来解释功能的核心功能,还是表明系统的来龙去脉的成熟文章都没关系。 重要的是,我们试图通过文档传达的信息是准确且可理解的。

在上一篇文章中 ,我们讨论了自动REST API生成的主题。 更准确地说,我们演示了如何使用Speedment的经过改进的Spring Integration插件为您的数据库生成完整的CRUD REST API。

今天,我们将使这一知识更进一步,并演示如何通过一次单击即可为REST API生成交互式文档。

如果您没有机会使用Speedment Spring插件,我们强烈建议您阅读上一篇文章,因为该文章包含遵循本指南的必要信息。

您喜欢Java Streams吗?

如果对这个问题的回答是“是!”,“绝对!” 或“哎呀!”,那么Speedment是适合您的工具。 Speedment是Java ORM工具箱和运行时,它使用纯Java Streams作为应用程序和数据库之间的接口。

除了已经熟悉的Streams API之外,Speedment还为最终用户提供了图形化工具,以便在几秒钟内生成数据库的Java表示,从而使他们完全可以停留在仅Java的环境中。

如果您想进一步了解Speedment,请前往
文档页面上 ,您将找到大量指南和示例。 在本文的其余部分,我们将重点介绍Speedment的Spring插件的新更新。

开始之前

为了生成REST API文档,Speedment使用了OpenAPI规范和Swagger UI的组合。

根据您是否从头开始,准备步骤会有所不同,但是无论起点如何,最终结果都是相同的。

如果您已按照上一篇文章中的指南进行操作,我们在其中解释了如何使用Speedment生成REST API,则只需向项目的pom.xml文件添加几个依赖项:

 < dependencies > ... < dependency > < groupId >io.springfox</ groupId > < artifactId >springfox-swagger2</ artifactId > < version >2.9.2</ version > </ dependency > < dependency > < groupId >io.springfox</ groupId > < artifactId >springfox-swagger-ui</ artifactId > < version >2.9.2</ version > </ dependency > ...  </ dependencies > 

另一方面,如果您是从头开始的话,请转到Initializer ,在这里您将能够在Spring支持下生成Speedment项目。 到达Initializer后,将为您提供大量用于配置项目的选项。 一个特别重要的配置选项是Initializer的Plugins部分。

要在新的Speedment项目中启用Spring支持,请选中“ Spring”选项旁边的复选框。 对项目配置满意后,继续并单击初始化器底部的“下载”按钮。

准备就绪后,可以通过从项目模板的根文件夹执行以下命令来启动Speedment Tool:

 mvn speedment:tool 

如果正确安装了插件,则会看到一些特定于Spring Boot的选项,可用于配置REST API和文档。

如果这是您第一次使用Speedment,则可能需要遵循“ Hello Speedment ”快速入门指南来熟悉工作流程。

昂首阔步的自动机

对于以下示例,我们将使用MySQL示例数据库Sakila。 您可以将其下载为独立实例或Docker容器。

当您打开Speedment Tool并成功连接到数据库时,将为您提供一个用户界面,其中包含有关数据库的元数据信息以及一些您可以配置的选项:

如果单击顶部横幅中的“ Generate”按钮,将生成数据库的Java表示。 要为您的REST API生成文档,必须启用在项目视图中找到的“生成REST文档”选项(可通过选择树中的顶部节点来访问该选项)。

启用后,其他配置选项将变为可用,使您可以进一步自定义生成的文档:

下次重新生成Spring项目时,将生成一些特定于OpenAPI的配置。 为了查看和使用生成的文档,您需要运行Spring应用程序。 为此,执行以下命令:

 mvn spring-boot:run 

一旦您的Spring应用程序启动并运行,您就可以在以下端点http:// localhost:8080 / swagger-ui.html上找到生成的Swagger文档。

根据您配置项目的方式,在生成的文档中可能会看到不同的结果。 例如,如果禁用某个表的REST API生成,则下次重新生成项目时,该表的端点将在文档中不可用。

借助生成的Swagger文档,您可以立即了解您的应用程序已注册了哪些REST终结点,每种终结点可使用的HTTP方法,并直接从Swagger UI对这些终结点执行HTTP请求:

如果不确定请求正文中需要什么,可以在文档底部“模型”部分下找到请求正文模型:

注意:连接到Swagger端点时,如果出现以下提示,请确保您的Spring入口点位于正确的程序包中(必须在Swagger配置所在的程序包上方或相同的程序包中):

通常,这表明Spring未扫描您的Swagger配置。

摘要

编写良好且易于理解的文档可能是一个漫长而乏味的过程。 借助Speedment的Spring Boot插件的新更新,用户可以在几秒钟内为其REST API生成交互式文档。

资源资源

文章“如何快速生成整个数据库CRUD REST API”

Speedment Initializer能够生成项目模板 在GitHub上加速

s

Per Minborg
米斯拉夫·米利切维奇(MislavMiličević)

翻译自: https://www.javacodegeeks.com/2020/03/java-spring-how-to-generate-an-entire-swagger-documented-crud-rest-api-with-speedment.html

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

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

相关文章

计算机中的英语六级作文万能模板,大学英语六级作文万能模板7篇

很多人都觉得六级很难&#xff0c;其实主要是作文不会写&#xff0c;今天我们为大家整理了一些六级作文万能模板&#xff0c;大家可以借鉴一下&#xff0c;相信会对大家的提高有所帮助。大学英语六级作文万能模板1∶ 阐述主题型要求从一句话或一个主题出发&#xff0c;按照提纲…

中的实践 中兴_中兴通讯5G智慧治水业务在千岛湖畔下姜村成功实践

近日&#xff0c;中兴通讯智慧治水业务在千岛湖畔下姜村成功实践。这一业务为实现千岛湖下姜村水域的智能化管理、立体化监控提供了可靠保障&#xff0c;也将浙江电信5G网络、中兴通讯5G端到端解决方案在试商用实践中再推进一步。下姜村曾先后获得“全国创先争优先进基层党组织…

consul宕机配置丢失_简单的配置死机

consul宕机配置丢失编写整个框架的目的是为了处理应用程序的配置。 我更喜欢一种简单的方法。 如果通过配置来表示“ 部署之间可能有所不同的所有内容 ”&#xff0c;那么我们应该尝试使配置保持简单。 在Java中&#xff0c;最简单的选项是不起眼的属性文件。 属性文件的缺点是…

html post前md5加密,post提交及MD5加密

C# POST提交/// /// post 网址提交////// 提交网站/// 参数/// 编码方式///public static string PostWebRequest(string postUrl, string paramData, Encoding dataEncode){string ret string.Empty;try{byte[] byteArray dataEncode.GetBytes(paramData); //转化HttpWebReq…

一加7充电_一加真无线耳机曝光,65W快速充电器获认证

一加8系列发布后&#xff0c;曾有消息显示&#xff0c;一加旗下还有一款被称为一加Z的手机将于今年7月登陆市场。现在&#xff0c;距离传言中提到的发布时间越来越近&#xff0c;也再次有消息提到了这一时间点。不过&#xff0c;这次爆料中的新品并不是手机产品。来自爆料人士 …

从工作中清除代码–使用JUnit 5,Mockito和AssertJ编写可执行规范

可执行规范是可以用作设计规范的测试。 通过启用公共语言&#xff08;在DDD世界中&#xff0c;这也称为无处不在的语言 &#xff09;&#xff0c;它们使技术和业务团队能够进入同一页面。 它们充当代码的未来维护者的文档。 在本文中&#xff0c;我们将看到一种编写自动测试的…

怎么使用starwind部署iscsi_2019 年总结 - 多环境多版本的部署

自己几乎经历了部署演进的所有阶段&#xff0c;手动部署、自动部署&#xff0c;部署到服务器、部署到容器。我们也在不断演进并追赶行业前沿的技术/理念。保守估计今年可以基本追赶到行业前沿的最低水平。工作中经历了部署语言的多样化&#xff0c;部署目标的演化/进化&#xf…

家用计算机注意哪些参数,电脑小白买内存条要注意哪些?主要看哪些参数?这些知识要掌握...

内存条是电脑的核心硬件之一&#xff0c;它的作用主要是为CPU服务的&#xff0c;电脑运行的时候&#xff0c;CPU从硬盘里调用数据通过总线寻址放在内存里&#xff0c;内存相当于缓冲处理区&#xff0c;处理好信息后再回馈给CPU&#xff0c;然后电脑再根据指令运行。内存没有记忆…

java 单元测试技巧_其他一些单元测试技巧

java 单元测试技巧在我以前的文章中&#xff0c;我展示了有关JavaBeans单元测试的一些技巧。 在此博客文章中&#xff0c;我将针对单元测试一些相当常见的Java代码&#xff08;即实用程序类和Log4J日志记录语句&#xff09;提供另外两个提示。 测试实用程序类 如果您的实用程序…

日照职业技术学院计算机怎么样,日照职业技术学院宿舍条件怎么样 住宿环境好不好...

又到了一年一度的新生入学季&#xff0c;今年考上日照职业技术学院的学子们对你们的新学校有没有期待&#xff1f;下文中有途网小编给大家整理了日照职业技术学院的宿舍环境&#xff0c;供参考&#xff01;日照职业技术学院宿舍环境如何大学宿舍是各位同学们在大学期间会陪伴我…

cam350怎么看顶层_蛋糕胚速学教程大全,适合初学者看哦!

蛋糕胚速学教程大全&#xff0c;适合初学者看哦&#xff01;烘焙蛋糕最难的还是装饰&#xff0c;对手残星人来说&#xff0c;好不容易切好了蛋糕胚&#xff0c;抹面费了老大劲还是凹凸不平&#xff0c;做出来像狗狗啃过似的&#xff5e;快来看这份蛋糕抹面技巧&#xff0c;教你…

Java 14的新功能

2020年3月17日&#xff0c;Oracle发布了名为Java 14的Java新版本&#xff0c;其中包括许多新功能&#xff0c;工具&#xff0c;安全性&#xff0c;调试和更新的文档方面的改进。 但是&#xff0c;Oracle还向您提供Java的较旧版本&#xff0c;因为它具有向后兼容性&#xff0c;因…

计算机学校教学大纲,中等职业学校计算机应用基础教学大纲

附件4&#xff1a;中等职业学校计算机应用基础教学大纲一、课程性质与任务计算机应用基础课程是中等职业学校学生必修的一门公共基础课。本课程的任务是&#xff1a;使学生掌握必备的计算机应用基础知识和基本技能&#xff0c;培养学生应用计算机解决工作与生活中实际问题的能力…

voms下的反射大师_VOMS旧版

VOMS旧版又叫做虚拟大师&#xff0c;有独立运行的系统&#xff0c;安卓可以支持各种版本&#xff0c;自定义分辨率&#xff0c;应有游戏多开&#xff0c;还有虚拟定位的功能&#xff0c;是用户的好帮手&#xff0c;需要的朋友快来下载吧。VOMS旧版介绍VMOS 是一款运行在安卓上的…

java ssh客户端_简单的Java SSH客户端

java ssh客户端可以使用jcabi-ssh在Java中通过几行代码通过SSH执行shell命令&#xff1a; String hello new Shell.Plain(new SSH("ssh.example.com", 22,"yegor", "-----BEGIN RSA PRIVATE KEY-----...") ).exec("echo Hello, world!&qu…

hbase中的row key_hbase中RowKey的设计规则

在关心到hbase中rowkey设计的时候&#xff0c;说明hbase基本的知识已经了解了。就直接上干货(如果不了解的可以参考我上面一片关于hbase的自我总结的文章&#xff0c;我觉得总结的还是很好的)。如果文章中有错误或是不规范的地方&#xff0c;欢迎随时找我哈rowkey长度原则rowke…

计算机一级上机考试试题题库,2016年计算机一级上机考试题库

2016年计算机一级上机考试题库第1题、 ****** 本套题共有5小题 ******(1)新建文档WDA01.DOC&#xff0c;插入文档WTA01.DOC的内容&#xff0c;将文中所有“星星”替换为“行星”&#xff0c;存储为文档WDA01.DOC。(2)新建文档WDA02.DOC&#xff0c;插入文档WDA01.DOC的内容&…

赞扬精心设计:基于属性的测试如何帮助我成为更好的开发人员

开发人员的测试工具箱就是其中之一&#xff0c;很少保持不变。 可以肯定的是&#xff0c;某些测试实践已被证明比其他测试更有价值&#xff0c;但是&#xff0c;我们仍在不断寻找更好&#xff0c;更快和更具表现力的方法来测试我们的代码。 基于属性的测试 是 Java社区中鲜为人…

docker项目部署 php_「Docker部署PHP+Vue项目」- 海风纷飞Blog

创建Docker映射目录—— vue_demo # Demo项目—— php_vue—— docker-compose.yaml—— nginx———— apps # 项目代码———— conf # nginx配置文件—————— nginx.conf———— log # nginx———— vhost # 虚拟机配…

在美国本科 计算机排名2015,(word)2015年美国大学专业排名汇总-以计算机专业排名为例.doc...

(word)2015年美国大学专业排名汇总-以计算机专业排名为例美国大学经常有一些国内没有的专业&#xff0c;而且由于国情不同&#xff0c;很多在国内的热门专业&#xff0c;在国外可能不是那么“吃香”&#xff0c;另外不是名校的专业就是最好的&#xff0c;可能某个普通大学的专业…