首页 > 代码库 > linux下使用apktool破解修改安卓apk

linux下使用apktool破解修改安卓apk

自己平常用linux操作系统,某时突然想改个安卓的游戏
(1)
安装jre
http://java.com/zh_CN/download/index.jsp
找到合适自己的版本

2、解压文件
tar -zxvf jrexxxx.tar.gz
将得到的文件夹jre1.7.0_45(我的文件夹名)移动到/usr/lib/java中去,如果是linux mint debian目录是/usr/lib/jvm/,下面我们假设是移动到java目录中
使用mv命令 mv jre1.7.0_45 /usr/lib/java

3、运行命令 $sudo vim /etc/environment
添加环境变量,直接添加到文件中去
JAVA_HOME="/usr/lib/java/jre1.7.0_45"
CLASSPATH="$JAVA_HOME/lib"
PATH="$JAVA_HOME/bin:$PATH"

如果原来就没有安装java, 手动export PATH="/usr/lib/java/jre1.7.0_45:$PATH"
否则执行下列步骤:
设置当前默认的java解释器
$sudo update-alternatives --install /usr/bin/java java /usr/lib/java/jre1.7.0_45/bin/java 300
运行命令
$sudo update-alternatives --config java
选择该安装版本

测试 
$ java -version
java version "1.7.0_45"
Java(TM) SE Runtime Environment (build 1.7.0_45-b18)
Java HotSpot(TM) Client VM (build 24.45-b08, mixed mode)
安装成功

(2)
http://code.google.com/p/android-apktool/
下载
apktool1.5.2.tar.bz2
apktool-install-linux-r05-ibot.tar.bz2

解压,取 aapt  apktool apktool.jar 到/usr/local/bin/下
使用方法 http://code.google.com/p/android-apktool/wiki/FrameworkFiles
http://code.google.com/p/android-apktool/wiki/ApktoolOptions
一般是apktool d 程序.apk 反编译后生成"程序"文件夹, 修改后 apktool b 程序/ 会在"程序/dist/"下生成新的"程序.apk"

(3)
除了apktool外,还有一种反编译的方法,可以查看java源代码的,二者结合在一起更强大
dex2jar  把dex文件转化成jar的工具
http://code.google.com/p/dex2jar/
下载它
dex2jar 使用教程
http://code.google.com/p/dex2jar/wiki/ModifyApkWithDexTool

jd-gui
http://jd.benow.ca/
下载 jd-gui-0.3.5.linux.i686.tar.gz
使用其中的jd-gui查看jar中的java代码

# 转换test_apk-debug.apk中的classes.dex为test_apk-debug_dex2jar.jar
d2j-dex2jar.sh -f -o test_apk-debug_dex2jar.jar test_apk-debug.apk
# 验证jar
d2j-asm-verify.sh test_apk-debug_dex2jar.jar
# 转换成jasmin格式 
d2j-jar2jasmin.sh -f -o test_apk_jasmin test_apk-debug_dex2jar.jar
卸载旧的apk

修改smail文件

再生成新的apk文件
# 生成jar
d2j-jasmin2jar.sh -f  -o test_apk_jasmin.jar  test_apk_jasmin/ 
# 验证jar
d2j-asm-verify.sh test_apk_jasmin.jar
# 转换成 dex
d2j-jar2dex.sh  -f -o classes.dex test_apk_jasmin.jar
# 生成一份拷贝 
cp test_apk-debug.apk test_apk-debug-toast.apk
# 替换test_apk-debug-toast.apk中的classes.dex 
zip -r test_apk-debug-toast.apk classes.dex
# 签名 apk
d2j-apk-sign.sh -f -o test_apk-debug-toast-signed.apk test_apk-debug-toast.apk
重新安装就可以了

(4)
最后把重新编译产生的 "程序.apk" 进行签名,否则是无法运行的

下载 signapk 这个网上搜一下很多 比如 http://ishare.iask.sina.com.cn/f/25267528.html
英文教程: http://www.londatiga.net/it/how-to-sign-apk-zip-files/

确保安装有openssl,生成key
openssl genrsa -out key.pem 1024
openssl req -new -key key.pem -out request.pem
openssl x509 -req -days 9999 -in request.pem -signkey key.pem -out certificate.pem
openssl pkcs8 -topk8 -outform DER -in key.pem -inform PEM -out key.pk8 -nocrypt

进行签名
java -jar signapk.jar certificate.pem key.pk8  程序.apk  签名.apk
完成, 作者:帅得不敢出门  程序员群:31843264

linux下使用apktool破解修改安卓apk