Android 逆向APK 文件格式 ( Android 应用安装 | Zip 文件格式 | 使用 Python 代码提取 APK 文件 )

Posted 韩曙亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android 逆向APK 文件格式 ( Android 应用安装 | Zip 文件格式 | 使用 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 目录中 ;

以上是关于Android 逆向APK 文件格式 ( Android 应用安装 | Zip 文件格式 | 使用 Python 代码提取 APK 文件 )的主要内容,如果未能解决你的问题,请参考以下文章

Android 逆向Android 逆向方法 ( 静态逆向解析 | 函数调用分析 | 动态运行跟踪 | 运行日志分析 | 文件格式解析 | 敏感信息分析 | 网络信息监控 | 环境伪装模拟 )

Android逆向文档阅读笔记-Android Application Fundamentals

Android逆向基础----APK文件结构

Android 逆向APK 文件处理脚本 ApkTool.py ( 脚本简介 | 用法 | 分析 APK 文件 )

Android 逆向APK 文件处理脚本 ApkTool.py ( 脚本简介 | 用法 | 分析 APK 文件 )

如何防止对 Android APK 文件进行逆向工程以保护代码?