菜单
一、SonarScanner安装(windows)
1.1下载压缩包并解压
https://docs.sonarqube.org/latest/analysis/scan/sonarscanner/
1.2 配置文件
修改conf/sonar-scanner.properties文件
#Configure here general information about the environment, such as SonarQube server connection details for example
#No information about specific project should appear here
#----- Default SonarQube server
sonar.host.url=http://192.168.8.21:9010
#----- Default source code encoding
sonar.sourceEncoding=UTF-8
1.3 配置环境变量
把bin目录放在环境变量中
data:image/s3,"s3://crabby-images/11406/11406c4b4655a5208c13220adaf5729ee3875f37" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图"
1.4 检测是否部署成功
data:image/s3,"s3://crabby-images/0fd9a/0fd9a22fec8b95b6283f2542b06638e60a1e3283" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图1 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图1"
二、实现代码扫描
2.1 在SonarQube-Service端创建项目
data:image/s3,"s3://crabby-images/50e3d/50e3da7bea1fb724a5b0f0719a5c98f5f4896655" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图2 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图2"
data:image/s3,"s3://crabby-images/651d8/651d826ab8b350d409146565dbd36a63988ddb26" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图3 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图3"
创建令牌Token
data:image/s3,"s3://crabby-images/8e983/8e983de999fe45f7b60a7cf663bd5e7e9857ddce" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图4 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图4"
data:image/s3,"s3://crabby-images/f674e/f674e5f92a8e2e623d49173aaad81f4fc21c2db0" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图5 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图5"
生成Sonar-scanner命令
data:image/s3,"s3://crabby-images/b18f9/b18f952e730bc0ce3d3a8cdea83980f2adaffd0d" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图6 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图6"
2.2在项目的根目录下创建sonar-project.properties
# must be unique in a given SonarQube instance
sonar.projectKey=php-demo
# --- optional properties ---
# defaults to project key
sonar.projectName=php-demo
# defaults to 'not provided'
sonar.projectVersion=1.0
# Path is relative to the sonar-project.properties file. Defaults to .
sonar.sources=.
# Encoding of the source code. Default is default system encoding
sonar.sourceEncoding=UTF-8
##如果是java项目需要添加下面binaries,并不要存在target/classes目录
##sonar.java.binaries=target/classes
扩展java扫描
data:image/s3,"s3://crabby-images/c26c6/c26c6adad066e9d0cb1b9d6baf0df7b2ccc2e199" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图7 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图7"
# must be unique in a given SonarQube instance
sonar.projectKey=java-hello2
# --- optional properties ---
# defaults to project key
sonar.projectName=java-hello2
# defaults to 'not provided'
sonar.projectVersion=1.0
#(指明只扫描ava语言)
sonar.language=java
# Path is relative to the sonar-project.properties file. Defaults to .
sonar.sources=src/com
# Encoding of the source code. Default is default system encoding
sonar.sourceEncoding=UTF-8
sonar.java.binaries=target/classes
2.2 执行扫描命令
sonar-scanner.bat -D"sonar.projectKey=php-demo" -D"sonar.sources=." -D"sonar.host.url=http://192.168.8.21:9010" -D"sonar.login=sqp_f6de55a9ec9a930516a24a8eae4cbcecb91a4324"
data:image/s3,"s3://crabby-images/df45a/df45a19327c4894b4b4f6682d7d2c63f0f5b8b22" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图8 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图8"
代码扫描成功。
2.3 查看报告
data:image/s3,"s3://crabby-images/70cf8/70cf8088bc51cdc39f0ed966c7c8eb9eb0f2ee15" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图9 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图9"
三、IDEA和SonarLint集成
3.1 添加Sonarlint插件
打开IDEA菜单,File –> Settings –> Plugins,搜索sonar插件,选择SonarLint进行Install,重启IDEA即可
data:image/s3,"s3://crabby-images/554ad/554ad0d22573bc010a0130a1fda9b1a03a005ad3" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图10 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图10"
安装完毕后,重启IDEA
3.2 IDEA配置SonarQube配置
打开IDEA菜单,File –> Settings –> Tools,打开SonarLint
添加关联的SonarQube服务端
data:image/s3,"s3://crabby-images/15a4a/15a4a3de1a8f666808493566b3d357e68e89b381" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图11 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图11"
创建Token
http://192.168.8.21:9010/account/security
data:image/s3,"s3://crabby-images/5c436/5c4363befb1f2d3017c56443b4e014fac855dfbb" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图12 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图12"
可以选择token或者密码登录
data:image/s3,"s3://crabby-images/8e17c/8e17cfb052c121547e3cb249dbab8037b538d003" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图13 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图13"
3.3 执行代码扫描
点击项目,右键SonarLint–>Analyze woth SpmarLint,查看log日志,确认连接server配置进行检测
data:image/s3,"s3://crabby-images/b15a3/b15a3684f043ea4c0e3b1b4f92faa0b77d2c2d34" alt="信息安全SonarQube系列(二)SonarScanner安装及实战案例插图14 信息安全SonarQube系列(二)SonarScanner安装及实战案例插图14"