SonarQube中文网站 > 使用技巧 > SonarQube扫描检测不到新代码 SonarQube扫描规则和检查点

SonarQube扫描检测不到新代码 SonarQube扫描规则和检查点

发布时间:2025-09-23 08: 00: 00

品牌型号:联想 E550C ThinkPad

系统:Windows 11

软件版本:SonarQube Server 25

SonarQube的代码扫描主要分为旧代码扫描和新代码扫描两部分,并会在报告中清晰呈现新代码与旧代码的对比分析结果,利用新旧代码的区分,帮助我们将注意力更多放在新代码中,而不被历史遗留问题分散注意力。但是,根据SonarQube设置不同,大家可能会遇到新代码未被正确识别或扫描规则和检查点未正确匹配等情况,因此本文将深入探讨SonarQube扫描检测不到新代码,SonarQube扫描规则和检查点的问题,确保大家得到的扫描结果全面可靠。

一、SonarQube扫描检测不到新代码

什么是新代码?不同的用户对于新代码的定义有所不同,有的人认为最近一次提交的代码是新代码,有的人则认为最近一个月的代码都是新代码,SonarQube考虑到大家的想法差异,因此对新代码的识别扫描,提供了个性化配置。

1、当我们扫描检测不到新代码时,首先使用管理员账号admin登录SonarQube网页端,进入后台Administration管理页面,在Configuration的“New Code”设置中,可以从两种新代码识别方式中选择一种来区分新旧代码。

方式一为按版本区分,上个版本则为旧代码,本版本为新代码;方式二按照天数区分,在“Specify a number of days”输入框中填写1到90间的天数,距今超过该天数以上的则为旧代码。

区分新代码
图1:区分新代码

2、如果选择了按照版本区分新旧代码,则需要在扫描时,通过配置文件或命令行参数“sonar.projectVersion”显示指定版本号,且每次扫描版本号需要及时变更。如果本次扫描和上次扫描使用同一个版本号,则会被视为是新代码。

指定版本号
图2:指定版本号

3、在多分支开发中,如果当前不处于Gitlab CI/CD等自动流中,则需通过“sonar.branch.name”参数手动指定扫描哪个分支,否则SonarQube会默认扫描主分支,此时在其他分支中则无法检测到新代码。

指定分支
图3:指定分支

二、SonarQube扫描规则和检查点

SonarQube扫描代码的原理是将代码解析成AST树,再将树通过内置规则遍历,来检测是否有匹配扫描规则的情况,匹配时则生成issues问题,所以规则是SonarQube静态代码分析的核心条件。SonarQube规则由SonarQube官方提供并按实际情况更新,非官方只能通过插件形式增加或修改规则。

在SonarQube网页端的Rules页面可以查看当前已有的内置规则,左侧Language栏可以筛选对应编程语言的规则,当前共有3794条规则,覆盖大多数问题场景。

规则页面
图4:规则页面

单击规则链接可跳转到规则页面,在“Why is the issue”中能看到具体规则的检查点,如图代码“return a <> b”所示,不等于号“<>”在新版Python中已被弃用,因此该检查点会被标记为问题,正确的代码形式应为“return a != b”。

检查点
图5:检查点

本文为各位读者讲解并解决了SonarQube扫描检测不到新代码,SonarQube扫描规则和检查点的难题。SonarQube的新旧代码区分扫描机制为开发团队提供了高效的代码质量检测手段,但前提是新代码必须被正确识别到,这其中一部分涉及新代码识别设置,另一部分涉及扫描参数,只有二者精准配合,再结合SonarQube的扫描规则和检查点功能,SonarQube检测结果才能又快又准。

展开阅读全文

标签:

读者也访问过这里:
SonarQube
从一开始就生成高质量的代码
立即购买
最新文章
SonarQube是代码测试工具吗 SonarQube如何配置SAML
软件代码质量管理从以前到现在经历了翻天覆地的变化,从最初的手工代码审查,到自动化测试工具的出现,再到如今SonarQube等综合检测应用的兴起,软件代码检测越来越正规、专业,带来的是软件市场水平整体的提高。并且SonarQube平台后续还支持通过SAML协议单点登录,大大便利了各大企业内部使用,成为如今众多企业进行代码检测的主要工具。那么SonarQube是代码测试工具吗,SonarQube如何配置SAML,接下来一起来了解一下。
2025-09-22
SonarQube分支分析是什么 SonarQube分支扫描配置与差异报告生成方法
在团队协作开发项目中,多分支并行开发已成为常态,每个不同的团队成员各自负责一部分功能或模块开发,最终由团队Leader统一审阅代码并合并分支。在此过程中,如何把控分支代码质量是一项重难点工作,如果全部代码由Leader人为查看,很容易出现错漏,因此常常需要结合SonarQube等带有分支分析的自动化代码检测工具进行。本文将重点向大家说明SonarQube分支分析是什么,SonarQube分支扫描配置与差异报告生成方法,帮助大家解决这一难点。
2025-09-22
SonarQube代码扫描如何启动 SonarQube代码扫描参数配置步骤
SonarQube提供的代码质量检测功能,在当今“两天一个版本”的快节奏开发环境中,已从“锦上添花”变成了“开发必需”,让我们摆脱传统的“先上线再修复”的恶性循环,它能在代码提交后精准捕捉潜在漏洞和安全问题,将质量问题扼杀在萌芽阶段。检测前我们需先启动扫描程序,下面讲解一下SonarQube代码扫描如何启动,SonarQube代码扫描参数配置步骤。
2025-09-22
SonarQube代码扫描显示cwe吗 SonarQube代码扫描怎么手动上传
互联互通的网络时代,安全性成为软件的主要检测项目之一,越多人使用的应用,它的安全性就越需要被保障,因为任何潜在的漏洞都可能被恶意利用,导致数据泄露、服务中断甚至更严重的系统性风险。因此,我们需要使用SonarQube等检测工具,它们既能帮助开发团队在早期发现代码BUG,还能识别CWE标准的安全漏洞。本文将详细回答大家关于SonarQube代码扫描显示cwe吗,SonarQube代码扫描怎么手动上传的疑问,帮助大家提升代码质量与安全等级。
2025-09-22
SonarQube扫描检测不到新代码 SonarQube扫描规则和检查点
SonarQube的代码扫描主要分为旧代码扫描和新代码扫描两部分,并会在报告中清晰呈现新代码与旧代码的对比分析结果,利用新旧代码的区分,帮助我们将注意力更多放在新代码中,而不被历史遗留问题分散注意力。但是,根据SonarQube设置不同,大家可能会遇到新代码未被正确识别或扫描规则和检查点未正确匹配等情况,因此本文将深入探讨SonarQube扫描检测不到新代码,SonarQube扫描规则和检查点的问题,确保大家得到的扫描结果全面可靠。
2025-09-22
SonarQube扫描原理 SonarQube扫描一定要先build么
什么是静态代码分析?静态代码分析指无需运行代码便可通过分析、检查代码的语法、结构、依赖等来检查代码的正确性,SonarQube的代码检测功能正是建立在静态代码分析原理之上。既然是分析静态代码,那SonarQube扫描前需要先编译代码吗?这个问题看似简单,实际涉及SonarQube扫描底层原理。想要获取正确代码检测结果,建议读者一起跟随本文,了解SonarQube扫描原理,SonarQube扫描一定要先build么的问题答案。
2025-09-22

读者也喜欢这些内容:

咨询热线 18015636924