首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

DevOps之静态代码扫描

Sonar 为代码的质量管理提供了一个平台,对传统的代码静态检测如 PMD、FindBugs 等工具进行整合,可以说是目前最强大的代码质量管理开源工具之一。...,扫描出来的违反代码规则的代码量非常大,一下子给开发人员巨大的压力,开发下意识会拒绝修改这么大量的问题。...所以必须对代码扫描规则进行筛选、定制,前期尽量挑选适量的、高级别的规则进行扫描应用,等开发习惯后再分阶段逐步应用更多的规则。Java建议加入阿里巴巴的p3c开发规范。...下面介绍常用的筛选策略: 1)针对不同系统进行评审、筛选、定制扫描规则集 企业内不同的系统(项目)的重要程度是有差异的,例如分为核心、重要、一般3种级别的系统,对不同系统定义的代码扫描规则集不同,例如:...通过一系列的筛选和调整后,Sonar的规则会适当减少,例如,下面是挑选了Sonar中专门由Findbugs进行扫描的规则,并且仅挑选严重级别为Blocker、Critical的规则,代码扫描规则的数量由原来的

1.8K10
您找到你想要的搜索结果了吗?
是的
没有找到

IOS静态代码扫描--分析与总结

IOS静态代码扫描--分析与总结 为了进一步加强代码质量,规范并减少代码缺陷,静态代码扫描是上过环节中必不可少的一部分。大多数都希望通过不同的途径提前发现日常测试中难发现的问题。...然而iOS静态代码扫描工具有不少,它们都有什么不同?我应该选哪一个?因此,本文主要针对主流的几个工具,对同步助手的代码进行扫描,并分析对比它们的扫描结果,再敲定后续的接入计划。...源代码通过clang语法分析后,生成了语法分析树(AST)后,可作为静态分析工具对AST进行分析。...Infer命令行调用方法: 安装python 2.7:MAC自带; 安装infer:brew install infer 4、oclint Oclint是针对C、C++和Objective C代码的静态扫描分析工具...(可进行缺陷扫描) (4)oclint扫描出的问题数量最多,但大多是开发不关注的问题,可过滤特定结果类型关注,更适合作为扫描代码复杂度的工具。

4.6K21

C++静态代码扫描哪家强?

静态代码分析是一种常用的“体检”方式,也是保证代码质量的重要手段。 1. 什么是静态代码分析?...静态代码分析是指无需运行被测代码,通过词法分析、语法分析、控制流、数据流分析等技术对程序代码进行扫描,找出代码隐藏的错误和缺陷,如参数不匹配,有歧义的嵌套语句,错误的递归,非法计算,可能出现的空指针引用等等...静态代码分析工具的优势 : 自动执行静态代码分析,快速定位代码隐藏错误和缺陷。 帮助代码设计人员更专注于分析和解决代码设计缺陷。...业界主流扫描工具概况 目前市场上的C++ 静态代码分析工具种类繁多且各有千秋,接下来主要介绍WeTest推出的TScanCode代码检查工具(TSC)和两种主流C++静态代码分析工具(cppcheck...内存泄漏是静态下很难检测的一种错误,当前各工具主要是从代码写法上检查内存分配和释放是否配对使用。

6.2K60

iOS 静态代码扫描之工具调研

作者:黄雪兰 团队:腾讯移动品质中心TMQ 为了进一步加强测试质量,同时探索测试左移在同步中的实践,iOS同步助手尝试接入静态代码扫描工具。希望通过不同的途径提前发现日常测试中难发现的问题。...然而iOS静态代码扫描工具有不少,它们都有什么不同?我应该选哪一个?因此,本文主要针对主流的几个工具,对同步助手的代码进行扫描,并分析对比它们的扫描结果,再敲定后续的接入计划。...源代码通过clang语法分析后,生成了语法分析树(AST)后,可作为静态分析工具对AST进行分析。...vxcodebuild -target QQPimPro -configuration Developer (4)可以看到生成报告在指定目录下 3、infer Infer是Facebook开源的用来执行增量分析的一款静态分析工具...Developer (7)项目代码所在目录下生成结果文件夹infer-out:report.csv、report.json 4、oclint Oclint是针对C、C++和Objective C代码的静态扫描分析工具

5.5K10

静态代码扫描方法及工具介绍

本文作者:国勇(信安之路特约作者) 静态扫描就是不运行程序,通过扫描源代码的方式检查漏洞,常见的方法也有多种,如把源代码生成 AST(抽象语法树)后对 AST 进行分析,找出用户可控变量的使用过程是否流入到了危险函数...当然静态扫描由于不运行程序也有好多事情处理不了,如程序通过运算得到的一个结果后,就没办法分析这个结果了,所以需要动态运行程序来解决这个问题,也就是动态扫描,动态扫描可以通过单元测试或人工扫描等方式,下面分别介绍一下...AST 扫描 与 正则匹配两种常见静态扫描方式。...效果图,左边是源码,右边是分析结果 jsprime 是一个静态代码分析工具,其核心是基于 Esprima ECMAScript 生成 AST 进行扫描,此工具有在 blackhat 上演讲过,他的主要功能有...: https://www.slideshare.net/nishantdp/jsprime-bhusa13new 1、JS 库 source 与 skin 识别 2、JQuery 及 YUI 框架识别

6.9K20

Android静态代码扫描效率优化与实践

小伙伴们,美美又来推荐干货文章啦~本文主要介绍Android静态扫描工具Lint、CheckStyle、FindBugs在扫描效率优化上的一些探索和实践,希望大家喜欢鸭。...Android项目常用的静态扫描工具包括CheckStyle、Lint、FindBugs等,为降低接入成本,美团内部孵化了静态代码扫描插件,集合了以上常用的扫描工具。...静态代码扫描耗时分析 Android项目的构建依赖Gradle工具,一次构建过程实际上是执行所有的Gradle Task。...对于一个已经存在的工程,如果没有使用过静态代码扫描,我们希望在接入扫描插件后续新增的代码能够保证其经过增量扫描没有问题。...总结与展望 本文主要介绍了在静态代码扫描优化方面的一些思路与实践,并重点探讨了对Lint、FindBugs、CheckStyle增量扫描的一些尝试。

1.6K10

JavaScript、js文件、Node.js静态文件

一、JavaScript 1、JavaScript认知 JavaScript(简称“JS”) 是一种解释型的脚本语言。广泛用于Web应用开发,对页面事件做出响应。...文件 js文件是指包含JavaScript代码,以“.js”为扩展名的文本文档,用于在网页中执行JavaScript指令;可以说JS文件是网页JavaScript客户端脚本文件。...三、Node.js node.js – Node是一个让JavaScript运行在服务端的开发平台。...四、静态文件 定义:不是由服务器生成的文件就是静态文件 包含:web项目中的图片、css、js、文本文件txt、脚本、等静态资源,不带jsp、asp、php页面的HTML页面 特点: 1 通常存放在...项目根目录下的static文件夹中 2 静态的一般对seo影响不大 五、其它 HTML 定义了网页的内容 CSS 描述了网页的布局 JavaScript 控制了网页的行为 版权声明:本文内容由互联网用户自发贡献

6.3K30

利用 SonarScanner 静态扫描 Rainbond 上的 Maven 项目

对代码进行静态扫描是一种非常常见的代码质量保证手段,这种扫描不仅仅可以检查到代码中的缺陷,应用各种业界最佳实践,也可以检查出安全方面的漏洞,给予项目代码全方位的提升。...在各种代码扫描方案之中,SonarQube 最为人熟知,应用最为广泛。各种持续集成方案都有自己的方式融入 SonarQube 进行代码的静态扫描工作。...今天介绍一种基于 SonarScanner 在 Rainbond 源码构建过程中,对 Java Maven 项目进行静态扫描的方法。...SonarScanner For Maven 简介使用 SonarScanner for Maven 对 Maven 项目进行代码静态扫描,是 SonarQube 官方推荐的默认扫描器。...Rainbond 自动构建对应服务组件的同时,触发 SonarScanner 扫描工作,并将扫描结果发送给 SonarQube 服务。SonarQube 服务分析扫描结果,生成代码检测报告。

85120

容器静态安全漏洞扫描工具Clair介绍

CVE扫描统计。...本文将介绍这块由CoreOS官方推出的容器静态安全漏洞扫描工具Clair,该工具也被多款docker registry集成,比如VMware中国开源的Harbor(CNCF成员项目)、Quary以及Dockyard...这种类型的设置避免了手动扫描,并创建了一个合理的接收端以便Clair的漏洞通知到位。仓库还可用于授权,以避免泄露用户不应当访问的镜像漏洞信息。...Clair可以集成到CI/CD管道中,如此一来当生成镜像时,将镜像推送到仓库之后触发Clair扫描该镜像的请求。...集成思路如下: 用户推送镜像到容器仓库,仓库根据设置的黑白名单选择是否调用Clair进行扫描 一旦触发Clair扫描,则等待扫描结果返回,然后通知用户 如果发现漏洞,则CI也同时阻止CD流程启动,否则CD

2.5K30

JS 静态类型检查工具 Flow

本文主要介绍了解决JS作为弱类型语言没有类型检查痛点的静态类型检查工具 Flow ,并且介绍了在WebStorm中使用Flow的方法,最后介绍了一些常用的Flow语法。 1....Flow是一个由Facebook出品的JavaScript静态类型检查工具,它与Typescript不同的是,它可以部分引入,不需要完全重构整个项目,所以对于一个已有一定规模的项目来说,迁移成本更小,也更加可行...或 webpack.dev.config.js、 webpack.prod.config.js、文件中添加: const FlowBabelWebpackPlugin= require('flow-babel-webpack-plugin...---- 网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~ 参考: 使用Flow来检测你的JS vue2.0项目配置flow类型检查 用flow.js...提升前端开发的体验 Flow静态类型检查及在Vue项目中的使用 如何在项目中使用 flow js

3K50

结合静态代码扫描来给插件间接口把把脉

插件间接口规则实现 考虑插件间接口是通过传递接口常量来完成数据传递,我们可以通过代码扫描来构建我们的上述规则,结合我们的自定义需求来看看目前android常用的三款静态代码扫描工具: [GvZqpUP.png...选定了工具之后实现部分就水到渠成了,按lint规则扩展来添加需要的检查规则,下图虚线模块是每个自定义规则需要扩展的地方: [W3hAE6A.png] 1、注册规则,声明扫描范围为JAVA_FILE_SCOPE...: [Eg0f0tR.png] [m3205Xm.png] (1)查找插件接口定义: 在扫描工具中我们可以按抽象语法树来进行代码节点的查找,在Android Lint中scanner通过lombok.ast...…… 插件间接口整理只是我们静态代码扫描在缺陷/规范扫描之外结合业务的一个小应用,通过梳理业务定义处理规则,把代码的问题回到代码中来处理。...结合业务代码扫描我们还可以做的更多,也许你也有更多的代码扫描的应用场景也欢迎大家一起探讨~ 关注微信公众号:腾讯移动品质中心TMQ,获取更多测试干货! [4IiAvkh.jpg]

1.2K60
领券