Android静态安全检测 - Intent隐式调用

2024-08-29 03:08

本文主要是介绍Android静态安全检测 - Intent隐式调用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Intent隐式调用 - android.content.Intent



一、API


1. 继承关系


【1】java.lang.Object

【2】android.content.Intent


2. 主要方法


【1】构造方法

  Intent()

 Intent(String action)

  Intent(Context context, Class cls)

  其他:Intent(Intent o)等


【2】Intent.setAction(String action)


【3】Intent.setClass(Context context, Class cls)


【4】Intent.setClassName(String packageName, String className)


【5】Intent.setClassName(Context context, String className)


【6】Intent.setComponent(ComponentName component)


【7】Intent.setPackage(String packageName)


【8】其他方法


https://developer.android.com/reference/android/content/Intent.html


二、Intent的隐式调用显示调用


1. 隐式调用


【1】setAction方法


【2】构造方法直接设置Action


2. 显示调用


【1】构造方法传入Component


【2】setComponent方法


【3】setClass/setClassName方法


【4】setPackage方法


3. 参考链接


http://blog.csdn.net/xiao__gui/article/details/11392987


三、触发条件


1. setAction方法


【1】对应到smali语句的特征:

  Landroid/content/Intent;->setAction(Ljava/lang/String;)

  Landroid/content/Intent;-><init>()

  const-string v1, "abc"

  去除系统Intent  “android.”

  显示调用的判断

       - Landroid/content/Intent;->setComponent(

       - Landroid/content/Intent;->setClass(

       - Landroid/content/Intent;->setClassName(

       - Landroid/content/Intent;->setPackage(


2. 构造方法直接设置Action


【1】对应到smali语句的特征:

  Landroid/content/Intent;-><init>(Ljava/lang/String;)

  const-string v1, "abc"

  去除系统Intent  “android.”

  显示调用的判断

        - Landroid/content/Intent;->setComponent(

        - Landroid/content/Intent;->setClass(

        - Landroid/content/Intent;->setClassName(

        - Landroid/content/Intent;->setPackage(


四、漏洞原理


【1】隐式intent没有明确指明哪些接收方有权限接收,恶意程序指定action标识后,可以获取intent内容,导致数据泄露,intent劫持,仿冒,钓鱼应用等风险


【2】更多内容


http://blog.csdn.net/wulianghuan/article/details/8508848


http://drops.wooyun.org/mobile/15202


五、修复建议


【1】建议使用显示调用方式发送Intent


【2】使用Intent.setPackage、Intent.setComponent、Intent.setClassName、Intent.setClass、new Intent(context,Receivered.class)中任一种方法明确指定目标接收方,显式调用intent


这篇关于Android静态安全检测 - Intent隐式调用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1116669

相关文章

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l