安卓漏洞学习(十八):Android加固基本原理

devtools/2025/1/8 8:18:52/

APP加固技术发展历程

在这里插入图片描述

APK加固整体思路

在这里插入图片描述
加固整体思路:先解压apk文件,取出dex文件,对dex文件进行加密,然后组合壳中的dex文件(Android类加载机制),结合之前的apk资源(解压apk除dex以外的其他资源,如manifest、res等),打包新的apk文件,并对新的apk文件进行对齐、签名。

Android加固原理

在这里插入图片描述
Dex文件整体加固原理如下:
在这里插入图片描述
该过程涉及到三个对象,分别为:

1.源程序

源程序也就是我们的要加固的对象,这里面主要修改的是原apk文件中的classes.dex文件和AndroidManifest.xml文件。

2.壳程序

壳程序主要用于解密经过加密了的dex文件,并加载解密后的原dex文件,并正常启动原程序。

3. 加密程序

加密程序主要是对原dex文件进行加密,加密算法可以是简单的异或操作、反转、rc4、des、rsa等加密算法。
  该加固过程可以分为如下4个阶段:
  (1) 加密阶段
  (2)合成新的dex文件
  (3)修改原apk文件并重打包签名
  (4)运行壳程序加载原dex文件加密阶段

加密阶段

主要是将把原apk文件中提取出来的classes.dex文件通过加密程序进行加密。
在这里插入图片描述

合成新的dex文件

这一阶段主要是将上一步生成的加密的dex文件和我们的壳dex文件合并,将加密的dex文件追加在壳dex文件后面,并在文件末尾追加加密dex文件的大小数值。
 在这里插入图片描述
在壳程序里面,有个重要的类:ProxyApplication类,该类继承Application类,也是应用程序最先运行的类。所以,我们就是在这个类里面,在原程序运行之前,进行一些解密dex文件和加载原dex文件的操作。

修改原apk文件并重打包签名

在这一阶段,我们首先将apk解压,会看到如下图的6个文件和目录。其中,我们需要修改的只有2个文件,分别是classes.dex和AndroidManifest.xml文件,其他文件和文件加都不需要改动。
  首先,我们把解压后apk目录下原来的classes.dex文件替换成我们在上一步合成的新的classes.dex文件。然后,由于我们程序运行的时候,首先加载的其实是壳程序里的ProxyApplication类。所以,我们需要修改AndroidManifest.xml文件,指定application为ProxyApplication,这样才能正常找到识别ProxyApplication类并运行壳程序。
在这里插入图片描述

运行壳程序加载原dex文件

Dalvik虚拟机会加载我们经过修改的新的classes.dex文件,并最先运行ProxyApplication类。在这个类里面,有2个关键的方法:

attachBaseContext和onCreate方法

ProxyApplication先是运行attachBaseContext再运行onCreate方法。
  在attachBaseContext方法里,主要做两个工作:读取classes.dex文件末尾记录加密dex文件大小的数值,则加密dex文件在新classes.dex文件中的位置为:len(新classes.dex文件) – len(加密dex文件大小)。然后将加密的dex文件读取出来,解密并保存到资源目录下然后使用自定义的DexClassLoader加载解密后的原dex文件
  在onCreate方法中,主要做两个工作:通过反射修改ActivityThread类,并将Application指向原dex文件中的Application创建原Application对象,并调用原Application的onCreate方法启动原程序。
在这里插入图片描述

链接:https://www.zhihu.com/question/51585199/answer/3297302964
来源:知乎


http://www.ppmy.cn/devtools/148475.html

相关文章

[CTF/网络安全] 攻防世界 PHP2 解题详析

翻译:你能给这个网站进行身份验证吗? index.php index.php是一个常见的文件名,通常用于Web服务器中的网站根目录下。它是默认的主页文件名,在访问一个网站时,如果没有特别指定页面文件名,则服务器会自动加…

U盘提示格式化?原因、恢复方案与预防措施全解析

一、U盘提示格式化现象概述 在日常使用U盘的过程中,我们有时会遇到一个令人头疼的问题——U盘插入电脑后,系统却弹出一个提示框,告知我们U盘需要格式化才能访问。这个提示往往伴随着数据的潜在丢失风险,让我们不禁为之心焦。U盘提…

Oracle删除归档日志

Oracle删除归档日志 1.运行环境2.检查数据库的归档配置3.使用RMAN删除归档文件4.归档状态不匹配 1.运行环境 操作系统:Windows Server 2019  Oracle版本:11gr2,即11.2 2.检查数据库的归档配置 打开CMD或POWERSHELL(win键R键后输入对应名称)…

掌握机器学习与MySQL集成实战Ruby和JavaScript辅助Redis缓存策略

掌握机器学习与MySQL集成实战Ruby和JavaScript辅助Redis缓存策略 文章导读 本文将深入探讨掌握机器学习与MySQL集成实战Ruby和JavaScript辅助Redis缓存策略的技术实践和创新方法。 掌握机器学习与MySQL集成实战:利用Ruby和JavaScript辅助Redis缓存策略 引言 随…

JVM类加载器

什么是类加载器 类加载器(ClassLoader)是Java虚拟机提供给应用程序去实现获取类和接口字节码数据的技术。 类加载器只参与加载过程中的字节码获取并加载到内存这一部分 类加载器的分类 类加载器分为两类,一类是Java代码中实现的&#xff0…

新零售模式下开源AI智能名片2+1链动模式S2B2C商城小程序源码的应用研究

摘要:新零售作为线上线下零售融合的新型商业模式,正在逐步改变传统零售业的面貌。然而,小型门店在SKU管理、供应商管理、运营效率等方面仍面临诸多挑战。本文旨在探讨开源AI智能名片21链动模式S2B2C商城小程序源码在新零售中的应用&#xff0…

DeepSeek v3为何爆火?如何用其集成Milvus搭建RAG?

最近,DeepSeek v3(一个MoE模型,拥有671B参数,其中37B参数被激活)模型全球爆火。 作为一款能与Claude 3.5 Sonnet,GPT-4o等模型匹敌的开源模型DeepSeek v3不仅将其算法开源,还放出一份扎实的技术…

智能工厂的设计软件 应用场景的一个例子:为AI聊天工具添加一个知识系统 之11 方案再探之2 项目文件(修改稿1)

(以下内容是第二次重建项目(“方案再探”)时的项目附件。) 为AI聊天工具添加一个知识系统 Part1 人性化&去中心化 前情提要 这一次我们暂时抛开前面对“智能工厂的软件设计”的考虑--其软件智能 产品就是 应用程序。直接将这些思维方式和方法论 运…