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

相关文章

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(