android静态分析 soot,使用Android Studio Lint静态分析

程序静态分析

程序静态分析是指在不运行代码的方式下,通过词法分析、语法分析、控制流、数据流分析等技术对程序代码进行扫描,验证代码是否满足规范性、安全性、可靠性、可维护性等指标的一种代码分析技术。

Java-Android代码常用的分析工具

Checkstyle

FindBugs

Soot

Lint

使用 Lint 改进您的代码

Lint是Android Studio提供的 代码扫描工具,自动化地对代码进行扫描,帮助改善代码结构的规范性和可维护性,提高代码质量。

Lint静态扫描的工作原理如下图。

format,png

Android Studio中Lint的操作步骤

Android Stuido Lint提供了 Specify Inspection Scope 面板,在面板中对代码扫描任务做个性化定义。

format,png

打开Specify Inspection Scope面板:菜单栏->Analyze->Inspect Code

设定扫描范围Custom Scope

在面板中可以配置Lint扫描的范围,其中File选项会根据面板弹出前光标所在位置显示三种状态:

Files:在打开的文件上调出面板,可以对当前打开的文件进行扫描;

Directory:在Project面板中选中名录调出面板,对选定的目录进行扫描;

隐藏:不提供此选项

个性化扫描范围设定

标题右侧的下拉框可以选择已有的自定义扫描配置

下拉框右侧的“…”按钮,可以调起自定义扫描配置面板,可以任意的为一项配置添加和删除待扫描的源文件。左侧一列是自定义的配置列表,他们将出现在上一层的下拉框内备选。

format,png

检查项设置

Specify Inspection Scope 面板上最后一项Inspection profile,指定在代码扫描过程中对哪些问题进行检查。系统默认只提供一个Default可选项,我们可以点击下拉框右边的“…”按钮添加个性化的可选项。

如下图,我们需要先把Default配置项Copy to Project,改个可爱的名字后就可以在新产生的配置项上进行编辑了。

第一步可以点击橡皮擦(图中被弹出框盖住了),把从Default中复制下来的选项全部清除,然后根据需要选择合适的集合即可。

其中Android、General、XML和Spelling是必选项,如果工程中只有Java代码,就只需要勾选Java一项就可以了,否则可能还需要选上kotlin、flutter、dart等相关的选项。

另外,上面说的那些选项,下面还有许多的子选项,并不是都必须的,可以根据需要选择部分子选项进行检查。

format,png

问题警告级别

选中检查项设置某一个选项,右侧会给出对应的描述和安全提醒级别。Android Studio Lint提供了六级安全提示,每种级别对应着不同的外观,重要程度不同,醒目的程度也不一样。

format,png

设置完所需的选项之后,点击右下角的“OK”,就可以使用这个设置集合了。

执行Lint静态扫描&查看结果

扫描范围和检查项设置完成之后,就可以执行静态扫描了。点击Specify Inspection Scope面板右下角的“OK”按钮,就开始执行扫描操作了。扫描完成之后,Android Studio底部会弹出Inspection Results面板, 可以根据安全级别或者检查项进行归类,到这里我们就可以根据扫描的结果对代码进行相应的整理和修改了。

format,png

参考文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值