文章目录
- 一、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 目录中 ;