反编译+重新打包APK

反编译:

只看图片资源:

如果我们只需要得到apk中的图片资源,这是最简单的,我们只需要将apk文件的后缀改成zip,然后将其解压,这样我们就可以一目了然地看到文件中的res路径,这里面包含着drawable等等,我们直接就可以得到图片资源了。

想看源码:

1.同样上面的步骤,当我们得到解压后的文件的时候,里面会有一个classex.dex的文件,它就是java文件编译再通过dx工具打包而成的。
2.我上传的文件中解压后,会有一个叫做dex2jar的工具,我们需要将classex.dex复制到dex2jar.bat的所在目录。在命令行下定位到dex2jar.bat所在的目录。
3.运行:“dex2jar.bat classes.dex”
会生成:classes.dex.dex2jar.jar;
这样会在dex2jar.bat所在目录生成一个 classes.dex.dex2jar.jar的jar包。
4.运行JD-GUI(jd-gui.exe),打开上面生成的jar包,即可看到源代码了。


到这为止,我们已经可以看到.java的代码了,此时我们还剩下一个工具,叫做apktool,我们还有一个任务没做,那就是反编译我们的.xml文件。

重新打包:

5.我们需要在命令行下,定位到apktool.bat的文件夹,输入命令:
apktool d C:\XXX.apk YYY
//我们非常建议直接把我们的工具,和apk都放在根目录也就是c:\的下面,上面的xxx是我们的apk的名字,yyy是反编译完文件夹的名字,如果这步执行成功,那么我们新的文件中的xml文件就是可读的了,可以用记事本打开了。

重新打包

6.将反编译完的文件重新打包成apk,很简单,输入:
apktool b c:***夹(你编译出来文件夹)即可

打包apk后的文件在目录C:*你上面编译出来文件夹下,生成了两个文件夹:build和dist

其中,打包生成的apk,在上面的dist文件夹下。


最后要说的就是,我们切不可做打包党,窃取他人的利益,反编译别人的东西,只是为了学习被人的长处,提高自己,报效祖国。当然,我们如果对方的apk是加壳的,或者sdk过高我们也有可能会失败,我们可以更新我们的工具,或找寻其它的办法。

我们工具的下载的链接是:
链接:http://pan.baidu.com/s/1hrlmFQW 密码:apeu