linux下,Android apk 反编译方法总结

总结网上分散的反编译方法,归类并亲测有效,其完整步骤如下:
一、资源反编译(推荐工具apktool)
        1. 下载apktool.jar以及相关文件:
	http://code.google.com/p/android-apktool/downloads/list 下载apktool1.4.3.bz2 和apktool-install-linux-r04-brut1.zip。
	2. 解压缩以上两个文件,分别得到apktool.jar和apktool-install-linux-r04-brut1文件夹。然后复制apktool.jar到
apktool-install-linux-r04-brut1文件夹中。
	3. 进入apktool-install-linux-r04-brut1目录,安装framework(如果要反编译各厂商手机自带的mms,phone之类的apk,因
为它们极大的依赖定制过的framework,所以需要此步骤。)
	./apktool if com.htc.resources.apk(以htc为例)
	4. 反编译资源:
	./apktool d ***.apk(如HtcContacts.apk)
二、代码反编译
        经过odex化的apk,按如下步骤反编译;没有odex化的apk,直接跳至第3步(使用apk包中的classes.dex)。
	1. odex转smali
	http://code.google.com/p/smali/downloads/list 下载四个文件:baksmali-1.4.0.jarbaksmalismali-1.4.0.jarsmali
放在同一个文件夹(我命名为odex-smali-dex)内。
	举例要对Mms.odex进行反编译,需将/system/framework里面的 android.policy.odex, bouncycastle.odex,core.odex,
core-junit.odex, ext.odex,framework.odex,services.odex和Mms.odex文件一同放入odex-smali-dex文件夹内
	进入odex-smali-dex,输入命令: java -jar baksmali-1.4.0.jar -a 10 -x Mms.odex -o Mms_out  得到smali文件。
	“ -a 10 ”代表api-level,即android版本号对应的级别。 -o 后为输出目录(默认名为out,里面的文件以.smali结尾)。
	2. smali转dex
	java -jar smali-1.4.0.jar Mms_out/ -o dex_out/Mms.dex   得到dex文件(Mms.dex)。
	3. dex转jar
	http://code.google.com/p/dex2jar/downloads/list 下载dex2jar-0.0.9.9.tar.gz,并解压,将dex文件拷到解压路径。
	进入解压目录,输入命令: ./d2j-dex2jar.sh Mms.dex 得到jar文件(Mms-dex2jar.jar)。
	4.运行jd-gui,打开Mms-dex2jar.jar。
	下载jd-gui-0.3.3.linux.i686.tar,解压即可运行。
1 . 把apk拷到apktool根目录下,执行:./apktool d xxx.apk,会生成xxx目录,里面有res目录(各种资源文件),smali目录(类似src目录,里面文件的语法不一样)及AndroidManifest.xml。 [*.apk->*.jar: sh ./dex2jar/dex2jar.sh xxx.apk,生成xxx_dex2jar.jar通过jd-linux看源码] 2 . 什么apk汉化啊,就到res/values里string.xml里修改字符串,或者拷贝一份values目录改为values-zh-rCN,再去里面修改string.xml里英文字符串改为中文,所谓的汉化就是这么简单。另外,有些图片里不是中文的得去改图片,那得用Photoshop了,图片也不能乱改,格式,图片大小(尺寸)得原来的。 3 . 修改smali文件,这个有些难度。比如有些apk安装了后要积分什么的,比如大于100才可以用的,其实这个值是用SharedPreference存放的,也就是存在xml里,,位置:/data/data/[包名]/shared_prefs的某个xml里,文件不多肯定是可以找到的。另外一种方法就是修改.smali文件也可以达到这目的,软件实现肯定是读取积分那个值给它修改一下就可以了,例如 const/16 v0 100 (其实就是 v0 = 100)这个语法有点像汇编,觉得还是比汇编简单,v0 v1 ...是寄存器,之前会跟变量关联的。具体的还是自己看看smali语法。 4 . 打包生成apk,执行:./apktool b xxx,会在xxx里面生成,一个dist目录,里面就是xxx.apk,但不能安装滴,提示(Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]),没有给这个apk签名, 5 . 签名,执行:sh ./dex2jar/d2j-apk-sign.sh ./xxx/dist/xxx.apk 就是给刚才那个apk签名,生成的文件还是xxx.apkapktool根目录下。这样就大功告成啦。 [请看:http://blog.csdn.net/zhouyuanjing/article/details/7446988]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值