反编译apk与重新打包

一、反编译出源码

1.反编译java代码需要先下载dex2jar工具,下载最新版本后解压。

2.将要反编译的apk文件重命名为zip格式并解压缩,注意其中的classes.dex文件,它存放了全部的java代码,将classes.dex文件拷贝到dex2jar解压后的根目录下。

3、打开cmd,进入dex2jar解压后的根目录,执行命令:

d2j-dex2jar classes.dex
反编译apk与重新打包_第1张图片
示例图

命令执行完后在对应目录下会生成classes-dex2jar.jar文件
4.要查看java代码,还需要下载jd-gui这个工具,下载地址:http://jd.benow.ca/,目前最新版是1.4.0,下载完后解压缩,并用jd-gui.exe打开上边反编译出来的jar文件

二、反编译资源文件

1、要反编译apk中的资源文件,就需要apktool这个工具了,下载地址:http://ibotpeaches.github.io/Apktool/install/,进入下载页面:
下载apktool.bat和apktool.jar这两个文件并放到同一文件夹
2、将要反编译的apk文件放到apktool文件夹,打开cmd,进入apktool文件夹目录,执行命令:

apktool d test.apk

执行成功后,在当前目录下会生成一个test文件夹:
其中,res文件夹下存放的是反编译出来的所有资源,smali文件夹下存放的是反编译出来的所有代码,AndroidManifest.xml则是经过反编译还原后的manifest文件。smali文件夹下的文件smali文件使用的是Android虚拟机所使用的寄存器语言,如果看的懂smail文件的话,就可以修改源代码的逻辑了,好可怕的事...当然这不是我们重点讨论的。

三、重新打包

1、编译修改后需要重新打包:同样在cmd中切换到apktool文件夹目录,执行命令:

apktool b test -o new_test.apk

执行成功后,在当前目录会生成一个新的new_test.apk文件
2、但是,这个apk并不能安装,因为需要重新签名。没有签名文件的话,通过Android Studio生成一个,将准备好的签名文件放到apktool文件夹根目录,继续在cmd执行命令:

jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore 签名文件名 -storepass 签名密码 待签名的APK文件名 签名的别名

注意,其中jarsigner命令文件是存放在jdk的bin目录下的,需要将bin目录配置在系统的环境变量中才可以在任何位置执行此命令。

3、最后可以通过如下命令验证apk签名是否成功:

jarsigner -verify -verbose -certs new_test_aligned.apk
反编译apk与重新打包_第2张图片
示例图

参考博客:http://www.jianshu.com/p/792a08d5452c

你可能感兴趣的:(反编译apk与重新打包)