idea快速生成crud_Java / Spring:如何快速生成完整的Swagger文档CRUD REST API

idea快速生成crud

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

在上一篇文章中 ,我们讨论了自动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的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配置所在的程序包上方或相同的程序包中):

这通常表明您的Swagger配置没有被Spring扫描。

摘要

编写良好且易于理解的文档可能是一个漫长而乏味的过程。 借助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

idea快速生成crud

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

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

相关文章

漫画:如何破解MD5算法

转载自 玻璃猫 程序员小灰 在之前的漫画中&#xff0c;我们介绍了MD5算法的基本概念和底层原理&#xff0c;没看过的小伙伴们可以点击下面的链接&#xff1a;《漫画&#xff1a;什么是MD5算法&#xff1f;》 这一次&#xff0c;我们来讲解如何破解MD5算法。 设MD5的哈希函数是…

自定义类加载器(ClassLoader + URLClassLoader)

【0】README 0.1&#xff09;本文主要对类加载器进行分析&#xff0c;且 URLClassLoader是 ClassLoader的子类&#xff1b; 0.2&#xff09;关于如何设置类加载器的加载路径&#xff0c;参见 对servlet容器的补充 【1】URLClassLoader类加载器 1.1&#xff09;URLClassLoad…

fork/join和线程池_从fork-join /线程池调用的Singelton bean中的访问spring请求范围缓存...

fork/join和线程池问题&#xff1a; 启用了Spring且其范围设置为Request的缓存需要由不在请求范围内的singleton bean访问。 解&#xff1a; Spring使您能够创建缓存&#xff0c;该缓存为请求范围保留数据。 例如 import org.springframework.cache.concurrent.ConcurrentMapC…

tomcat(2)一个简单的servlet容器

【0】README 0.1&#xff09;本文部分文字转自 “深入剖析Tomcat”&#xff0c;旨在学习 一个简单的servlet容器 的基础知识&#xff1b; 0.2&#xff09;for complete source code, please visit https://github.com/pacosonTang/HowTomcatWorks/tree/master/chapter2 0…

漫画:什么是Base64算法

转载自 玻璃猫 程序员小灰 ValueChar ValueChar ValueChar ValueChar0A16Q32g48w1B17R33h49x2C18S34i50y3D19T35j51z4E20U36k5205F21V37l5316G22W38m5427H23X39n5538I24Y40o5649J25Z41p57510K26a42q58611L27b43r59712M28c44s60813N29d45t61914O30e46u6215P31f47v63/控制字符&am…

soapui 测试soap_使用SoapUI调用不同的安全WCF SOAP服务-基本身份验证,第一部分

soapui 测试soap在这个分为三部分的系列中&#xff0c;我将演示如何使用SoapUI API工具来调用安全的WCF SOAP服务。 第一篇文章将着重于创建将要测试的系统的服务。 第二篇文章将介绍在基本身份验证机制保护的情况下调用它所需的步骤。 在最后一部分中&#xff0c;我将对初始服…

dmn是大脑中哪个区域_DMN中的函数式编程:感觉就像再次重读我的大学课程一样...

dmn是大脑中哪个区域在本文中&#xff0c;我想分享有关DMN中递归支持的有趣见解&#xff0c;并重点介绍FEEL语言的特定属性如何使功能性编程结构能够在DMN中建模。 我们将从一个基本示例开始&#xff0c;以演示FEEL语言和DMN构造的“商业友好”性质如何使我们能够解决一个通常…

对Servlet容器的补充

【0】README 0.1&#xff09;本文是对 一个简单的servlet容器 的补充&#xff1b; 【1】Servlet容器 1.1&#xff09;通过一个简单的servlet容器这篇博文&#xff0c;我们看到&#xff1a;其中的核心代码是 类加载器&#xff0c; 然而&#xff0c;在我follow 其代码&#xf…

漫画:什么是A*寻路算法

转载自 玻璃猫 程序员小灰比如像这样子&#xff1a;第一步&#xff1a;把起点放入OpenList第二步&#xff1a;找出OpenList中F值最小的方格&#xff0c;即唯一的方格Node(1,2)作为当前方格&#xff0c;并把当前格移出OpenList&#xff0c;放入CloseList。代表这个格子已到达并…

apache ignite_Kubernetes集群上的Apache Ignite和Spring第2部分:Kubernetes部署

apache ignite以前&#xff0c;我们已经成功创建了第一个由Apache Ignite支持的Spring boot Application。 在此博客上&#xff0c;我们将重点介绍Kubernetes方面需要做的事情&#xff0c;以便能够启动我们的应用程序。 如先前博客所述&#xff0c;我们需要制定我们的Kuberne…

漫画:什么是布隆算法

转载自 玻璃猫 程序员小灰两周之前——爬虫的原理就不细说了&#xff0c;无非是通过种子URL来顺藤摸瓜&#xff0c;爬取出网站关联的所有的子网页&#xff0c;存入自己的网页库当中。但是&#xff0c;这其中涉及到一个小小的问题......URL去重方案第一版&#xff1a;HashSet 创…

2016第11届四川省高校计算机(软件)院长论坛纪要(旁听)

​【0】README 0.1&#xff09;该论坛与16年4月8日在西南交大召开&#xff0c;为贺西南交大120周年华诞&#xff1b; 0.2&#xff09;以下内容是小生在该论坛上的部分旁听内容&#xff08;仅仅是部分&#xff09;&#xff0c; 感觉很新鲜&#xff0c;故分享之&#xff1b; 0…

selenium自动化测试_为什么在生产中进行Selenium自动化测试对于您的下一个版本至关重要?...

selenium自动化测试您是否认为仅仅是因为您的Web应用程序在过渡环境中以飞快的速度通过&#xff0c;它对于生产环境也将是相同的&#xff1f; 您可能需要重新考虑&#xff01; 特别是&#xff0c;如果我们指的是跨浏览器测试 &#xff0c;则需要确保跨各种操作系统&#xff0c…

java.lang.ExceptionInInitializerError的原因

【0】README 0.1&#xff09;本文转自 http://blog.csdn.net/fykhlp/article/details/6236316&#xff1b; 【1】正文如下 这个错误是说变量初始化出现问题&#xff0c;通常出现在静态变量尤其是单例模式。这种问题往往是初始化顺序不对造成的&#xff0c;下面举个简单的例子。…

漫画:Bitmap算法 整合版

转载自 玻璃猫 程序员小灰两个月之前——为满足用户标签的统计需求&#xff0c;小灰利用Mysql设计了如下的表结构&#xff0c;每一个维度的标签都对应着Mysql表的一列&#xff1a;要想统计所有90后的程序员该怎么做呢&#xff1f;用一条求交集的SQL语句即可&#xff1a;Select…

tomcat(3)连接器

【0】README0.1&#xff09;本文部分内容转自“深入剖析tomcat”&#xff0c;旨在学习 tomcat(3)连接器 的基础知识&#xff1b;0.2&#xff09;Catalina 中有两个主要的模块&#xff1a;连接器&#xff08;ServerSocket&#xff09; 和 容器&#xff08;Servlet容器&#xff0…

java正则表达式验证_如何在Java中验证电话号码(正则表达式+ Google libphonenumber)...

java正则表达式验证关于如何在不同国家&#xff08;例如美国&#xff0c;美国&#xff09;使用Java验证电话号码的快速指南。 带有正则表达式和Google libphonenumber API的示例程序。 1.简介 在本教程中&#xff0c;我们将学习如何在java中验证电话号码 。 这主要是为了验证美…

漫画:什么是B-树

转载自 玻璃猫 程序员小灰 本文提到的「B-树」&#xff0c;就是「B树」&#xff0c;都是 B-tree 的翻译&#xff0c;里面不是减号-&#xff0c;是连接符-。因为有人把 B-tree 翻成 「B-树」&#xff0c;让人以为「B树」和「B-树」是两种树&#xff0c;实际上两者就是同一种树。…

tomcat(4)Tomcat的默认连接器

【0】README0.0&#xff09;本文部分文字描述转自&#xff1a;“深入剖析tomcat”&#xff0c;旨在学习 tomat(4)Tomat的默认连接器 的基础知识&#xff1b;0.1&#xff09;Tomcat中的连接器是一个独立的模块&#xff0c;可以插入到servlet容器中&#xff0c;而且还有很多连接器…

kafka mirror_SSL Kafka经纪人从Kafka Mirror Maker迁移到Brooklin的挑战

kafka mirror问题 从卡夫卡镜子制造商转移到布鲁克林有我在这里所写的优势。 但是&#xff0c;进行这种迁移并不容易&#xff0c;因为它本来应该如此。 我面临的主要挑战是&#xff1a;在消费者Kafka经纪人和Brooklin之间建立SSL连接 解 SSL问题 事实证明&#xff0c;这个问题…