文章目录
一、Android 应用安装
二、APK 文件格式
三、使用 Python 提取 APK 文件
一、Android 应用安装
APK 是 Android 应用的安装文件 , 现在也有 AAB 格式的 , AAB 安装包也可以导出 APK 安装文件 ;
应用安装时 , 会将 APK 安装包拷贝到 /data/app/packageName/ 目录下的 base.apk ,
如 : 某应用会将 apk 文件拷贝到 /data/app/com.qidian.QDReader-GTqLCxuMlq6CJtnOVz1LgQ==/base.apk 位置 ;
APK 安装目录参考 【Android 逆向】应用安装目录 ( Android 应用的默认安装目录 | 查找 Android 应用的安装目录 | 查询当前正在运行的应用包名 | 根据包名查询应用安装路径 ) 博客 ;
/data/data/package.name/lib 是应用自带的 so 动态库 , 在应用安装时安装的文件 ;
/data/data/com.qidian.QDReader/lib文件是软链接文件 , 真实的文件地址是 /data/app/com.qidian.QDReader-GTqLCxuMlq6CJtnOVz1LgQ==/lib/arm 地址 , 这是应用的安装目录 ;
lrwxrwxrwx 1 root root 66 2021-10-26 10:10 lib -> /data/app/com.qidian.QDReader-GTqLCxuMlq6CJtnOVz1LgQ==/lib/arm
参考 【Android 逆向】应用数据目录 ( files 数据目录 | lib 应用自带 so 动态库目录 | databases sqlite3 数据库目录 | cache 缓存目录 ) 博客 ;
二、APK 文件格式
Android 的 APK 安装包使用的数据格式就是 zip 格式 , 直接使用 zip 工具解压即可 , 也可以将文件命后缀改为 .zip 后解压 ;
Zip 文件格式中 , 每个文件都是由 文件头 + 文件数据 + 数据描述符 构成 , 如果有多个文件 , 则上面的 文件头 + 文件数据 + 数据描述符 数据 重复存放 即可 ;
Zip 文件中 还有一个 核心目录 , 以及 目录结束标识 ;
在 010 Editor 工具中 , 打开 apk 文件 , 然后选择 " 菜单栏 / 模板 / Zip 模板 " , 即可以 Zip 格式解析该 APK 文件 ;
50 4B 03 04 开始的文件 , 就是 Zip 文件 , 这是 Zip 文件的标识 ;
三、使用 Python 提取 APK 文件
使用 Python 提取 APK 文件完整代码 :
import os # 如果没有使用 pip install zipfile 安装 import zipfile # 提取 APK 中的文件 def extract_apk(apk_path: str): # 创建 ZipFile 实例对象 zip_file = zipfile.ZipFile(apk_path) # 解压目录 , 删除 "app.apk" 的后 4 个字符 ".apk" , 即 "app" out = apk_path[:-4] # 创建目录 os.mkdir(out) # 提取 zip 文件 zip_file.extractall(out) # 关闭 zip 文件 zip_file.close() def main(): extract_apk('app.apk') if __name__ == '__main__': main()
执行后会将 app.apk 文件解压到 app 目录中 ;