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

相关文章

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

一分钟带你上手Python调用DeepSeek的API

《一分钟带你上手Python调用DeepSeek的API》最近DeepSeek非常火,作为一枚对前言技术非常关注的程序员来说,自然都想对接DeepSeek的API来体验一把,下面小编就来为大家介绍一下... 目录前言免费体验API-Key申请首次调用API基本概念最小单元推理模型智能体自定义界面总结前言最

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

redis防止短信恶意调用的实现

《redis防止短信恶意调用的实现》本文主要介绍了在场景登录或注册接口中使用短信验证码时遇到的恶意调用问题,并通过使用Redis分布式锁来解决,具有一定的参考价值,感兴趣的可以了解一下... 目录1.场景2.排查3.解决方案3.1 Redis锁实现3.2 方法调用1.场景登录或注册接口中,使用短信验证码场

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

解读静态资源访问static-locations和static-path-pattern

《解读静态资源访问static-locations和static-path-pattern》本文主要介绍了SpringBoot中静态资源的配置和访问方式,包括静态资源的默认前缀、默认地址、目录结构、访... 目录静态资源访问static-locations和static-path-pattern静态资源配置

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex