Android 逆向


Android 逆向

前言

参考资料:

从零开始Android逆向教程(一)——初探Android逆向 - 吾爱破解 - 52pojie.cn

《安卓逆向这档事》一、模拟器环境搭建 - 吾爱破解 - 52pojie.cn

这里主要摘要一些笔记和自己的想法

应用上架前需要经过编译、签名、生成后缀为apk的文件,才能发布到应用商城,我们逆向就是从apk开始

工具准备

Android IDE: Android Studio(老朋友了)(签名生成软件APK)

模拟器:雷电模拟器9

反编译工具: dex2jar(将dex文件转为jar文件)、jd-gul(将jar文件转为java代码)

反编译资源工具:APKTool(apk逆向工具)

dex2jar和jd-gui配套使用,用于逆向代码部分,APKTool用于逆向res文件夹下的图片布局等部分。

定制Android开源软件:Magisk LSPosd

image-20250415140217995

image-20250415135845251

image-20250415141909784

APK

apk结构

Android Package

这里搬过来apk结构

文件注释
assets目录存放APK的静态资源文件,比如视频,音频,图片等
lib 目录armeabi-v7a基本通用所有android设备,arm64-v8a只适用于64位的android设备,x86常见用于android模拟器,其目录下的.so文件是c或c++编译的动态链接库文件
META-INF目录保存应用的签名信息,签名信息可以验证APK文件的完整性,相当于APK的身份证(验证文件是否又被修改)
res目录res目录存放资源文件,包括图片,字符串等等,APK的脸蛋由他的layout文件设计
AndroidManifest.xml文件APK的应用清单信息,它描述了应用的名字,版本,权限,引用的库文件等等信息
classes.dex文件classes.dex是java源码编译后生成的java字节码文件,APK运行的主要逻辑
resources.arsc文件resources.arsc是编译后的二进制资源文件,它是一个映射表,映射着资源和id,通过R文件中的id就可以找到对应的资源

AndroidManifest.xml

AndroidManifest.xml文件是整个应用程序的信息描述文件,定义了应用程序中包含的Activity,Service,Content provider和BroadcastReceiver组件信息。每个应用程序在根目录下必须包含一个AndroidManifest.xml文件,且文件名不能修改。它描述了package中暴露的组件,他们各自的实现类,各种能被处理的数据和启动位置。

属性定义
versionCode版本号,主要用来更新,例如:12
versionName版本名,给用户看的,例如:1.2
package包名,例如:com.zj.52pj.demo
uses-permission android:name=””应用权限,例如:android.permission.INTERNET 代表网络权限
android:label=”@string/app_name”应用名称
android:icon=”@mipmap/ic_launcher”应用图标路径
android:debuggable=”true”应用是否开启debug权限

双开

原理解释
修改包名让手机系统认为这是2个APP,这样的话就能生成2个数据存储路径,此时的多开就等于你打开了两个互不干扰的APP
修改Framework对于有系统修改权限的厂商,可以修改Framework来实现双开的目的,例如:小米自带多开
通过虚拟化技术实现虚拟Framework层、虚拟文件系统、模拟Android对组件的管理、虚拟应用进程管理 等一整套虚拟技术,将APK复制一份到虚拟空间中运行,例如:平行空间
以插件机制运行利用反射替换,动态代{过}{滤}理,hook了系统的大部分与system—server进程通讯的函数,以此作为“欺上瞒下”的目的,欺骗系统“以为”只有一个apk在运行,瞒过插件让其“认为”自己已经安装。例如:VirtualApp

【VirtualAPP 双开系列08】如何实现多开 - UID_virtualapp 使用-CSDN博客

汉化(字符串查找)

image-20250415150852664

JVM、Dalvik、ART

JVM是JAVA虚拟机,运行JAVA字节码程序
Dalvik是Google专门为Android设计的一个虚拟机,Dalvik有专属的文件执行格式dex(Dalvik executable)
Art(Android Runtime)相当于Dalvik的升级版,本质与Dalvik无异


文章作者: W3nL0u
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 W3nL0u !
  目录