方法评论

Spring 团队创建了两种创建新项目的方式和一种修改现有项目的方式。我们发现最佳方法是使用 Spring Initializr 生成项目,然后使用 boot add 命令进行添加。以下部分解释了为什么这是最佳方法。

Initializr

创建新的 Spring Boot 项目的常用方法是使用 Initializr,网址为 start.spring.io。Spring CLI 提供了与 Initializr 交互的命令。请参阅 Initializr,但也提供了其他创建新项目的方法,并解决了为现有项目添加代码或配置的“第二天”用例。

使用 Boot New

boot new 命令允许您从源代码仓库中已存在的项目创建新项目。boot new 命令允许您指定一小组选项以根据您的需求进行自定义(例如更改包名),但它不提供 Initializr 那样的依赖项选择。

boot new 的方法是克隆一个现有仓库,该仓库除了项目的依赖项之外,还包含完整可用的代码和配置。这种方法使您或您的团队成员可以轻松创建多个项目原型,因为它们是源代码仓库中常规的 Spring 项目,可以通过 CI 流程验证其工作。有关更多信息,请参阅 创建新项目

使用 Boot Add

然后,在初始项目创建之后,您可以使用 boot add 命令根据需要添加额外的代码和依赖项。此命令智能地将现有项目合并到您当前的项目中。与 boot new 命令一样,现有项目是源代码仓库中常规的 Spring 项目,可以编译并通过 CI 流程验证其工作。有关更多信息,请参阅 “boot add”指南

模板化代码和配置

或者,您可以使用用户定义命令添加额外的代码和依赖项,这些命令依赖于使用模板引擎来创建代码和配置。有关更多信息,请参阅 用户定义命令指南。使用模板引擎并让用户轻松贡献调用这些模板的命令的方法受到了 hygen 项目的启发。

总结

虽然两种添加额外代码和依赖项的方法都有其用例,但从头开始创建新项目时,我们发现从工作项目开始更容易。您不仅可以获得公司所需的批准依赖项,还可以获得代码、配置和测试。这是一个起点,消除了选择依赖项和从教程复制代码的繁琐工作和不确定性。通常,这些教程过于基础,不遵循常见的最佳实践约定,并且没有测试。

使用模板创建新项目可能是一个挑战。我们认为,为新项目模板化 Java 代码比从现有工作项目克隆新项目更困难。创建模板、运行模板然后编译生成的项目这个循环是脆弱的。但是,我们发现创建较小的代码块和配置更适合模板化方法——例如,使用 spring controller new 向当前项目添加控制器,或者使用 spring feature new 添加一些文件,例如带有 @Controller@Service@Repository 注解的类。

您的体验可能有所不同,但 Spring CLI 中提供了这两种类型的代码生成。

© . This site is unofficial and not affiliated with VMware.