0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

移动应用安全常用组件Soot、Flowdroid简介和基本使用

科技怪授 来源:科技怪授 作者:科技怪授 2022-10-13 09:12 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

Soot

简介

soot是java优化框架,提供4种中间代码来分析和转换字节码。

l Baf:精简的字节码表示,操作简单

l Jimple:适用于优化的3-address中间表示

l Shimple:Jimple的SSA变体

l Grimple:适用于反编译和代码检查的Jimple汇总版本。

soot提供的输入格式有:java、android、class等

输出格式有:Java字节码、android字节码、Jimple、Jasmin、shimple、baf等,这些实际业务中常使用的,当然还有其它的格式,这里不再一一列举。

借助soot对android的分析能力,我们可以进一步分析安卓应用的安全漏洞,比如组件暴露、加密算法等存在的安全问题。

基本使用

可以GIT下载最新的soot jar包,我下载的是4.1.0版本中的sootclasses-trunk-jar-with-dependencies.jar 包,这个包应该自带了soot所需要的所有依赖。下载完成后使用powershell进入jar文件所在的文件夹,可以输入以下命令:

java -cp sootclasses-trunk-jar-with-dependencies.jar soot.Main查看soot相关的信息![]image.png

首先我们来看soot怎么分析java代码(这里以class文件分析为例):

第一步,配置soot环境信息

StringBuffer** cp = new **StringBuffer();

cp .append(".");

cp .append(File. pathSeparator + apiPath );

cp .append(File.**pathSeparator + "C:Program FilesJavajre1.8.0_171lib
t.jar"
+ **File.**pathSeparator **

** + "C:Program FilesJavajre1.8.0_171libjce.jar");System.setProperty("soot.class.path", cp**.toString());

第二步,设置soot的配置属性(各属性说明可以参考GIT上官方文档信息)

image.png

第三步,拿到代码信息

image.png

现在,我们在看看soot怎么分析android apk

image.png

同样,我们可以得到apk的代码信息,包括class、method、attribute等,基于这些进行进一步分析并应用到实际检测业务中。

使用场景

使用Soot对Android应用进行静态分析,目前包括主要的检测场景:

l 检测应用中敏感字符串url和email、IP等

l 检测应用中风险代码片段

l 检测应用可能存在的漏洞,如组件暴露、过度申请权限、不安全加密算法等

FlowDroid

简介

FlowDroid(github链接)是目前对Android app进行污点分析效果最好的工具之一。 污点分析的目的其实很简单,就是为了检查是否应用中是否存在从污点源到泄漏点的数据流。 但是它的优点在于它构建的数据流精度很高,可以对上下文,流,对象和字段敏感,从而使得分析结果非常精确。

![]image.png

image.png

它实现精准分析的原因有几点:

l 1. 它对Android声明周期进行了比较完整的构建,例如Activity中的OnCreate,OnResume等。通过抽象一个dummyMain作为分析的入口来支持Android应用的分析;

l 2. 它实现了精准的数据流分析,其中包含前向污点分析和后向别名分析。他们的实现其实都是基于heros的数据流分析框架来实现的。这里面的算法比较复杂,我的理解是这两种分析都是满足上下文敏感和流敏感的,后向分析的算法提供了对象敏感和字段敏感的支持;

l 3. 它支持简单的native code的污点分析

l 当然,它也存在一些不足之处,包括:

l 1. 不能对组件间(Intent)的污点传播进行分析

l 2. 隐式流问题

l 3. native code不能完美支持

尽管存在一些不足之处,在各大会议上也已经提出了数十种新的静态污点分析算法,相比FlowDroid在一些数据集或是DroidBench上有着更快的运行速度以及更优的精准度。但FlowDroid仍然是公共资源中可获取的静态污点分析工具的唯一选择,因为很多paper提供的源代码几乎没有注释与文档,导致使用极其困难;另外科研人员往往仅在有限的测试集上进行了运行,所以去使用这样的程序不可避免的会遇到Bug。相比之下,FlowDroid作为被持续维护的一款框架,其稳定性上具备了一定的保证,同时其底层的Soot框架强大的功能与较为完善的文档,使得FlowDroid上手难度相对较低。

基本使用

环境配置

FlowDroid的配置方法有两种,可以直接下载相关jar包,也可以使用maven配置依赖。jar包可以去FlowDroid的GitHub上进行下载,仅需soot-infoflow-android-classes.jar和soot-infoflow-classes.jar两个文件即可,另外去Soot的仓库 下载包含了heros与jasmin的sootclasses-trunk-jar-with-dependencies.jar,将上述三个包加入项目依赖便完成了FlowDroid的配置

运行

整个FlowDroid最顶层的类便是soot.jimple.infoflow.android.SetupApplication,大部分的设置与运行都可以通过操作这个类的实例进行。SetupApplication既可以在调用runInfoflow()时传入配置参数,也可以在初始化SetupApplication时或初始化后传入配置参数。SetupApplication的初始化函数以及runInfoflow函数有多种不同参数类型的实现,可以查阅源码后根据情况选择,这里仅提供我自己使用的一种方式:

关于Source、Sink

污点分析中的source点表示污点分析的起始点,而sink点表示污点分析的结束点。换言之,FlowDroid在“扫描”这个apk后,会从source点开始分析数据流,当数据流“流到”sink点时将其标注。FlowDroid中的source与sink均为类方法,在soot-infoflow-android下有提供一份SourcesAndSinks.txt的文件,是FlowDroid当时使用的一些可能涉及到访问隐私数据的api,从里面很容易看出声明文件的格式:

每一行作为独立的声明,%开头的表示注释,可以根据应用需求自行添加删减Source与Sink的声明。

使用场景

Flowdroid本身输出结果只是数据流信息,需要结合我们定制source、sink信息产生业务价值,一般有以下使用场景:

l 隐私数据泄露检测

l 污点传播类问题检测

l Android组件间数据传递风险检测

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 移动应用
    +关注

    关注

    0

    文章

    67

    浏览量

    15973
  • JAVA
    +关注

    关注

    20

    文章

    3006

    浏览量

    116828
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    晶科能源五星防火组件筑牢安全防线

    光伏行业高质量发展背景下,高密度住宅、商业楼宇等核心场景对光伏组件安全需求日益严苛,其中防火性能更是场景适配的核心关键,光伏组件安全标准也随之持续升级。
    的头像 发表于 04-20 17:45 1447次阅读

    GB 47372-2026发布:移动电源安全标准全面升级解读

    强制性国家标准GB 47372-2026正式发布,移动电源行业将迎来近年来最重要的一次安全升级。随着移动电源在消费电子领域的广泛应用,其安全性问题持续受到监管部门与市场的高度关注。目前
    的头像 发表于 04-18 14:38 251次阅读
    GB 47372-2026发布:<b class='flag-5'>移动</b>电源<b class='flag-5'>安全</b>标准全面升级解读

    预期功能安全是什么?(下)

    ​ 4. SOTIF各阶段活动简介 4.1 规范定义和设计 功能规范的定义和对设计的考虑: 功能描述:对预期的功能、支持子系统和组件的功能的描述 ​ 性能目标:为实现预期功能而安装的传感器、控制器
    发表于 04-10 11:11

    晶科能源五星防火组件如何重塑光伏安全新标杆

    在PV EXPO 2026现场,晶科能源全球首发的五星防火组件成为焦点。它凭什么被称为光伏安全新标杆?答案就在下方视频中——点击观看现场讲解,看它如何通过全球最严苛的“双A级防火认证”。
    的头像 发表于 03-20 14:59 464次阅读

    示波器无源探头附件包:组件清单与专业使用指南

    无源探头是电子测量中最常用的测试工具,而它的附件包,就是保障测量精度、拓展应用场景的关键配套。不同品牌(如普科科技 / PRBTEK、泰克、是德科技等)的无源探头附件包组件略有差异,但核心
    的头像 发表于 02-24 09:54 243次阅读
    示波器无源探头附件包:<b class='flag-5'>组件</b>清单与专业使用指南

    Amphenol柔性印刷电路组件:设计新选择

    了解一下。 文件下载: Amphenol FCI BergStak® FPC跳线.pdf 一、Amphenol FPC组件简介 Amphenol的BergStak®、MezzoStak®、Conan
    的头像 发表于 12-12 10:10 665次阅读

    便携式EL检测仪:光伏组件的“移动探伤师”

    便携式EL检测仪:光伏组件的“移动探伤师”柏峰【BF-EL】光伏组件的“健康隐患”往往藏于表面之下——隐裂的硅片、虚焊的焊带、失效的电池片,这些肉眼难辨的缺陷会悄悄加速组件衰减,直接影
    的头像 发表于 11-24 17:18 817次阅读
    便携式EL检测仪:光伏<b class='flag-5'>组件</b>的“<b class='flag-5'>移动</b>探伤师”

    移动电源FCC认证办理

    移动电源(PowerBank)办理FCC认证是出口美国市场前的必要步骤之一。下面为你详细介绍FCC认证的类型、流程、资料、周期和费用:一、FCC认证简介FCC
    的头像 发表于 10-29 16:45 1794次阅读
    <b class='flag-5'>移动</b>电源FCC认证办理

    便携式EL检测仪:光伏组件缺陷检测的移动“透视眼”

    便携式EL检测仪:光伏组件缺陷检测的移动“透视眼”柏峰【BF-EL】在光伏电站运维与组件质量管控中,组件内部缺陷(如隐裂、断栅、虚焊、黑心片等)是影响发电效率与使用寿命的关键隐患。
    的头像 发表于 10-15 10:20 975次阅读
    便携式EL检测仪:光伏<b class='flag-5'>组件</b>缺陷检测的<b class='flag-5'>移动</b>“透视眼”

    移动电源 PCBA 开发方案全解析

    移动设备普及的当下,移动电源已成为人们日常生活和工作中不可或缺的配件。而移动电源的性能与可靠性,很大程度上取决于其内部的 PCBA(印刷电路板组件)。本文将全面解析
    的头像 发表于 07-28 11:02 1058次阅读

    TP4337芯片重新定义移动电源安全范式

    2025年夏季的消费电子行业危机,将电芯材料隐患与供应链透明度问题暴露于聚光灯下。这场风波揭示了一个核心命题:移动电源的安全防护必须从芯片层级构建基础防线。天源中芯的TP4337单芯片解决方案为移动电源提供了
    的头像 发表于 07-26 14:22 980次阅读
    TP4337芯片重新定义<b class='flag-5'>移动</b>电源<b class='flag-5'>安全</b>范式

    如何监听组件再次显示的事件?

    ​ ##HarmonyOS 应用开发## 我们知道,对于组件的生命周期,有aboutToAppear和aboutToDisAppear,即监听这个组件被挂载和卸载的事件,和被@Entry修饰的页面
    发表于 06-30 18:02

    如何实现组件截图 -- componentSnapshot

    等,文字和图片都是根据用户信息动态生成的,整个证书在显示的时候是通过Stack组件去完成的,如果只是在程序里显示那么当然很简单,但是还需要将其作为一张图片保存到相册里。 按照我以前的做法,就是直接
    发表于 06-30 17:45

    浅谈OCP SAFE服务器组件安全注意事项

    保护超大规模数据中心组件(包括 CPU、存储控制器和硬件安全模块)免受网络威胁对于维护超大规模数据中心的安全至关重要,以防范可能危及整个网络的漏洞。现代供应链涉及多家供应商和复杂的集成点,在
    的头像 发表于 06-23 10:16 1054次阅读

    KaihongOS操作系统:Button按钮组件介绍

    Button 按钮组件,可快速创建不同样式的按钮。 常用接口 Button Button(options: ButtonOptions) 创建可以包含单个子组件的按钮。 参数: 参数名类型必填
    发表于 04-25 07:09