如何反编译一个android程序二

前面讲到用工具反编译出java代码,结果很难看明白,而且dex文件居然有两个,一通google才知道,新的技术,multidex,最新androidstudio默认就这样了。呃,我是新人,不折腾了。有兴趣可以参考下面的文章:
http://gold.xitu.io/entry/5705b2712e958a0057a5f735
http://www.cnblogs.com/wingyip/p/4496028.html

正好在这个关键时刻,网上买的非虫大大的书到了(电子版看的太累,还是纸质舒服),这个系列文章以后基本都是参考这本书了。

由于前面用的是androidstudio,有坑,后面改为eclipse-juno,java,jee或者mobile版都可以,然后是CDT插件,ADT插件,AndroidSDK,NDK,好了,环境安装完毕。

1.反编译APK

apktool d test.apk outdir

2.分析APK文件

3.修改smali文件代码

4.重新编译APK并签名

apktool b outdir

signapk.jar是android源码包中的一个签名工具,源码目录/build/tools/signapk/SignApk.java,编译后在/out/host/linux-x86/framework目录中,签名文件可以使用android源码中的testkey.pk8与testkey.x509.pem。
新建signapk.bat文件,内容如下:

 java -jar "%~dp0signapk.jar" "%~testkey.x509.pem" "%~testkey.pk8" %1 signed.apk

四个文件放在同一个目录下,运行下面命令:

signapk test.apk

签名如果成功会在当前目录下生成signed.apk文件。

5.安装测试

启动模拟器或者连接真机,命令行下输入:

 adb install signed.apk

如果不能安装,可以先卸载前面的版本:

 adb uninstall test.apk

运行新的APP就可以看到前面自己修改的效果了。

你可能感兴趣的:(移动安全)