Sonar实现自定义Java扫描规则

本文档介绍了如何使用SonarQube实现自定义Java扫描规则。首先,从GitHub下载官方模板,并参照提供的教程进行操作。重点在于调整pom.xml文件,以确保SonarQube 8.9 LTS版本的兼容性。在打包过程中,由于未将Resources目录下的资源包含进jar,导致启动SonarQube时报错。解决办法是在pom.xml中添加打包参数,确保资源文件正确打包。
摘要由CSDN通过智能技术生成

下载官方提供的模板:https://github.com/SonarSource/sonar-java.git

参考官方链接:https://github.com/SonarSource/sonar-java/blob/master/docs/CUSTOM_RULES_101.md 教程

关于pom.xml:

我们根据SonarQube的版本来选择对应的pom文件,我使用的SonarQube版本是8.9 LTS。

初始化工程之后我们根据教程来一步一步填充模板后,打包。

我在这一步遇到的问题是:打出的jar在放入$SONAR_HOME/extensions/plugins后启动SonarQube报错:

java.lang.IllegalStateException: Can’t read resource: org/sonar/l10n/java/rules/java/

这是因为打包时没有将Resources路径下的资源打入jar包导致根目录中不存在该路径。
在pom.xml增加打包参数即可:

<!--打包时将resource下的文件一起打包-->
SonarQube是一个用于静态代码分析的开源平台,而SonarScanner则是SonarQube的命令行客户端,用于在本地项目上运行分析并将结果上传到SonarQube服务器。如果你想自定义扫描过程中的Properties文件配置,可以按照以下步骤操作: 1. **创建或修改`sonar-project.properties`**: - 在你的项目的根目录下,通常会有一个名为`.sonar-project.properties`的文件,这是默认的SonarScanner配置文件。你可以在这里添加或编辑你需要的配置项。 ```properties # 示例配置 sonar.sources=src/main/java sonar.java.binaries=target/classes sonar.java.libraries=lib/*.jar sonar.exclusions=**/generated/** # 避免扫描生成的代码 # 如果你想覆盖特定扫描规则文件 sonar.scan.coverage.exclusions=**/excludedFromCoverage.txt ``` 这里的配置项包括源码目录、目标文件夹、依赖库路径等,以及自定义的排除规则。 2. **环境变量覆盖**: - 如果某些配置只适用于特定环境,你可以通过系统环境变量来设置。例如,`SONAR_SCANNER_OPTS`可以用来传递额外的参数给SonarScanner。 ```bash export SONAR_SCANNER_OPTS="-Dsonar.projectKey=myProjectKey" ``` 3. **自定义Properties文件**: - 如果需要更复杂或者跨多个项目的情况,你可以创建一个单独的Properties文件(如`mycustom.properties`),然后在`sonar-project.properties`里引用它: ```properties sonar.project.properties=relative/path/to/mycustom.properties ``` 记得在执行`sonar-scanner`命令时加上这个配置。 4. **执行扫描**: - 使用`sonar-scanner`命令扫描项目,比如: ```bash ./path/to/sonar-scanner ``` **相关问题--:** 1. 如何在SonarQube中设置全局的Properties文件? 2. SonarScanner如何读取环境变量的配置? 3. 我可以在哪些地方找到关于SonarScanner更多配置选项的帮助文档?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值