搭建SpringBoot脚手架工程(2):代码格式化/质量审核/提交检查

前言

接上篇文章搭建SpringBoot脚手架工程,SpringBoot简单脚手架工程springboot-simple-scaffold已经利用Spring官方提供的平台搭建完成,但是作为一个企业级的脚手架需要考虑的更多,如团队统一代码格式,代码质量审核,代码提交检查等,这篇文章让我继续来完善脚手架。

统一代码格式

代码格式管理比较常用的插件是checkstyle,但这个插件用起来需要一些额外配置,团队中的每个人都需要在自己的Idea中下载插件然后导入配置,这无疑增加了一些工作量。后来我发现有一款更好用的代码格式化插件spotless,可以以更简单的方式进行代码格式化,在本次脚手架工程中我决定使用spotless来进行统一的代码格式管理。

  • 配置
    在build.gradle配置文件中新增spotless插件,并按需扩展spotless配置,各项配置的说明参考注释,这里值得一提的是格式化形式有多种可以选择,因为我个人不喜欢googleJavaFormat格式化的缩进形式,所以使用了palantirJavaFormat,其他如removeUnusedImports/importOrder/formatAnnotations等配置是一致的。
    plugins {
    	id "com.diffplug.spotless" version "6.12.0"
    }
    spotless {
    	java {
       	 	//googleJavaFormat()
        	palantirJavaFormat()//格式化形式
        	removeUnusedImports()//移除无用Import
        	importOrder()//导入顺序
        	formatAnnotations()//注解格式化
    	 }
    }
    
  • 效果检验
    刻意在ScaffoldController中导入了无用的Import,然后故意将ScaffoldController的代码格式弄的非常混乱,如以下截图:
    在这里插入图片描述
    然后执行./gradlew spotlessApply命令,提示成功后我们再查看ScaffoldController,发现代码格式变得正常,同时无用的import也被移除了,证明spotless代码格式化插件配置成功。
    在这里插入图片描述
    在这里插入图片描述

代码质量审查

代码静态审查工具有很多,如FindBugs,Sonar,PMD等,本脚手架工程采用的审查工具是PMD。PMD(Programming Mistake Detector)是一个静态代码分析器,它可以报告在应用程序代码中发现的问题。

  • 配置
     plugins {
    	id 'pmd'
     }
     pmd {
    	consoleOutput = true //结果输出到控制台
    	toolVersion = "6.39.0" //工具版本
    	rulesMinimumPriority = 5 //规则优先级
    	ruleSets = ["category/java/bestpractices.xml"] //规则集合
     }
    
  • 效果检验
    刻意在ScaffoldController中新增一个无用的私有方法testPmd(),如以下截图:
    在这里插入图片描述
    执行./gradlew pmdMain,发现命令无法通过,提示避免无用私有方法,证明PMD代码检查插件配置成功。
    在这里插入图片描述

代码提交检查

  • 说明
    在企业级项目开发中一般都会要求本地代码提交到远程仓库前必须经过一些检查,避免污染远程仓库,这些检查一般会包括代码格式检查,代码质量审查,代码测试检查等,这就要求开发人员每次push前都得去执行一下相关命令,但难免会有忘记的时候,这种情况下可以配置git hooks来进行自动检查。
    git hooks是执行git相关命令时会预执行的脚本,在项目根目录.git/hooks下可以看到很多后缀是sample的脚本文件,这些文件后缀是sample的脚本文件默认不会生效,如果希望生效则需要去掉.sample并修改脚本内容,以pre-commit为例,当执行git commit命令时会预先执行pre-commit脚本中的内容,git push同理。在这里插入图片描述* 配置
    在build.gradle中配置自定义task,将预先写好的pre-commit和pre-push脚本放置在项目根目录的./scripts/hooks文件夹下。
    tasks.register('installGitHooks', Copy) {
    	from './scripts/hooks/pre-commit', './scripts/hooks/pre-push'
    	into './.git/hooks'
    }
    
    在这里插入图片描述
    pre-commit的作用就是commit前先执行spotlessJavaApply进行代码格式化在这里插入图片描述
    pre-push的作用就是push前先执行pmdMain和test单元测试进行代码质量检查在这里插入图片描述
  • 检验
    首先执行./gradlew installGitHooks将hooks安装到./.git/hooks目录下,故意在ScaffoldController新增无用import然后执行git commit,这时会发现无用的import已经不存在,证明我们的hooks配置是生效了。
    在这里插入图片描述
    在这里插入图片描述
    我们再执行git push会发现无法push成功,这是因为最开始我为了测试PMD新增的无用私有方法没有去掉,而我们在pre-push中又会去执行pmdMain的校验。
    在这里插入图片描述
    只需要去掉在ScaffoldController中新增的无用方法,再次进行git push,会发现push成功。
    在这里插入图片描述

结语

到这里我们的SpringBoot脚手架工程已经初具雏形,具备统一代码格式,代码质量审核,代码提交检查的能力。但似乎还是有些不够,大家想想我们的脚手架还有什么不足吗?下篇文章告诉你答案。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要搭建Spring Boot脚手架,您可以按照以下步骤进行操作: 1. 首先,确保您已经安装了Java和Maven。您可以在命令行窗口中运行`java -version`和`mvn -v`命令来验证它们的安装情况。 2. 接下来,您可以选择使用Spring Initializr来生成一个新的Spring Boot项目。您可以访问https://start.spring.io/ 并填写所需的项目元数据,例如项目名称、包名、依赖等。然后点击"Generate"按钮来下载生成的项目文件。 3. 解压下载的项目文件,并使用您喜欢的集成开发环境(IDE)打开它。例如,您可以使用IntelliJ IDEA或Eclipse。 4. 在IDE中,导入解压后的项目文件。具体操作取决于您使用的IDE。在IntelliJ IDEA中,您可以选择"Import Project",然后选择项目文件夹并点击"Open"。 5. 一旦项目导入成功,您可以开始编写代码了。在src/main/java目录下,您可以找到一个自动生成的主应用程序类(通常以`Application`结尾)。您可以在这个类中编写您的业务逻辑和处理程序。 6. 您还可以在src/main/resources目录下找到应用程序的配置文件。您可以使用它来配置数据库连接、端口号等。 7. 当您完成代码编写后,您可以使用Maven构建项目。在命令行窗口中,导航到项目根目录并运行`mvn clean install`命令。这将编译代码并生成可执行的JAR文件。 8. 最后,您可以在命令行窗口中运行`java -jar target/your-project-name.jar`命令来启动应用程序。请确保将"your-project-name"替换为您的实际项目名称。 这样,您就成功搭建了一个Spring Boot脚手架。您可以根据您的需求进行进一步的开发和定制化。祝您好运!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值