Android 反编译

本文介绍基础使用步骤,具体详见 郭霖大神的博客

https://github.com/skylot/jadx

准备

1. apk
例如 xxxx.apk,进行解压,所需 classes.dex 文件

2. dex2jar
dex文件转换成jar文件 ,所需 d2j-dex2jar.sh 文件(windows所需d2j-dex2jar.bat文件)
下载地址:http://sourceforge.net/projects/dex2jar/files/

3. apktool
用于最大幅度地还原APK文件中的9-patch图片、布局、字符串等等一系列的资源。
下载地址:http://ibotpeaches.github.io/Apktool/install/
将下载好的俩个文件放在 /usr/local/bin 文件下

步骤

1. dex 转jar
命令行执行 d2j-dex2jar classes2.dex ,(根据文件位置对命令进行相应的修改),生成 classes2-dex2jar.jar 文件

2. 查看
将上一步生成的 classes2-dex2jar.jar 文件放到中 JD-GUI.app 进行查看,假如apk进行混淆则会出现类似 a,b,c的类名或方法名

3. 反编译资源文件
反编译资源文件,一些资源文件出现乱码,例如 Androidmanifest.xml,执行命令 apktool d xxxx.apk,生成对应的 xxxx 文件夹

其他

回编译失败

报错信息如下

分析:
看到错误信息之后自然的看到了 Course by,然后一顿查找brut.androlib.AndrolibException: brut.common.BrutException: could not execbrut.androlib.res.AndrolibResources.aaptPackage问题,网上给出的答案都是 apktool 和 apt 的问题,最终都没有解决。

解决:
给出的警告 W,没有引起重视,解决之后即可。

I: Using Apktool 2.3.1
I: Checking whether sources has changed...
I: Checking whether resources has changed...
I: Building resources...
S: WARNING: Could not write to, using /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/ instead...
S: Please be aware this is a volatile directory and frameworks could go missing, please utilize --frame-path if the default storage directory is unavailable
W: AndroidManifest.xml:1: error: No resource identifier found for attribute 'compileSdkVersion' in package 'android'
W:
Exception in thread "main" brut.androlib.AndrolibException: brut.androlib.AndrolibException: brut.common.BrutException: could not exec (exit code = 1): [/var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/brut_util_Jar_4889616069972529220.tmp, p, --forced-package-id, 127, --min-sdk-version, 15, --target-sdk-version, 22, --version-code, 950, --version-name, 3.1.5, --no-version-vectors, -F, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/APKTOOL7906429744768739041.tmp, -0, arsc, -0, db, -0, assets/ye_license, -0, arsc, -I, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/1.apk, -S, res, -M, //AndroidManifest.xml]
    at brut.androlib.Androlib.buildResourcesFull(Androlib.java:492)
    at brut.androlib.Androlib.buildResources(Androlib.java:426)
    at brut.androlib.Androlib.build(Androlib.java:305)
    at brut.androlib.Androlib.build(Androlib.java:270)
    at brut.apktool.Main.cmdBuild(Main.java:227)
    at brut.apktool.Main.main(Main.java:75)
Caused by: brut.androlib.AndrolibException: brut.common.BrutException: could not exec (exit code = 1): [/var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/brut_util_Jar_4889616069972529220.tmp, p, --forced-package-id, 127, --min-sdk-version, 15, --target-sdk-version, 22, --version-code, 950, --version-name, 3.1.5, --no-version-vectors, -F, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/APKTOOL7906429744768739041.tmp, -0, arsc, -0, db, -0, assets/ye_license, -0, arsc, -I, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/1.apk, -S, /Users/hych/Open/Frida/Workspace/shoudiantong/shoudiantong/res, -M, /Users/hych/Open/Frida/Workspace/shoudiantong/shoudiantong/AndroidManifest.xml]
    at brut.androlib.res.AndrolibResources.aaptPackage(AndrolibResources.java:456)
    at brut.androlib.Androlib.buildResourcesFull(Androlib.java:478)
    ... 5 more
Caused by: brut.common.BrutException: could not exec (exit code = 1): [/var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/brut_util_Jar_4889616069972529220.tmp, p, --forced-package-id, 127, --min-sdk-version, 15, --target-sdk-version, 22, --version-code, 950, --version-name, 3.1.5, --no-version-vectors, -F, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/APKTOOL7906429744768739041.tmp, -0, arsc, -0, db, -0, assets/ye_license, -0, arsc, -I, /var/folders/t7/j_22fh39067g7c84wbbljs600000gn/T/1.apk, -S, /Users/hych/Open/Frida/Workspace/shoudiantong/shoudiantong/res, -M, /Users/hych/Open/Frida/Workspace/shoudiantong/shoudiantong/AndroidManifest.xml]
    at brut.util.OS.exec(OS.java:95)
    at brut.androlib.res.AndrolibResources.aaptPackage(AndrolibResources.java:450)
    ... 6 more

com.googlecode.d2j.DexException: not support version

版本不同,使用对应的版本

参考1

参考2

你可能感兴趣的:(Android 反编译)