APK反编译过程

本文详细介绍使用apktool、dex2jar和jd-gui反编译APK的过程,包括资源文件提取、Java源码还原及源码查看。适用于希望了解或修改APK内部结构的开发者。

处于某些不可告人的目的,项目上需要反编译某个apk。

参考了网上教程,基本都是利用三大神器:apktool、dex2jar、jd-gui 

本文主要参考了https://www.cnblogs.com/sthu/p/9098720.html

工具介绍:(末尾附上下载链接)

apktool  

     作用:资源文件获取,可以提取出图片文件和布局文件进行使用查看

dex2jar

     作用:将apk反编译成java源码(classes.dex转化成jar文件)

jd-gui

     作用:查看APK中classes.dex转化成出的jar文件,即源码文件

其实主要就是利用dex2jar查看其源码。apktool 查看布局文件这一步无所谓。

我们知道apk实际上就是一个压缩包,可以利用rar压缩工具解压打开查看。

主要步骤记录一下:

1.apktool 查看布局文件(这一步仅为查看其布局文件,若是仅为了看源码,可以省略不做)

apktool工具包,解压得到3个文件:aapt.exe,apktool.bat,apktool.jar ,将需要反编译的APK文件放到该目录下,

打开命令行界面(运行-cmd) ,定位到apktool文件夹,输入以下命令:apktool.bat d -f  test-daiwei.apk  test 

(如果是apktool.jar高版本,则需要加入参数-o指定其输出目录test,如:apktool.bat d -f  test-daiwei.apk  -o test )

如果你想将反编译完的文件重新打包成apk,那你可以:输入apktool.bat   b    test(你编译出来文件夹)便可(这个我没有执行过)

2.  Apk反编译得到Java源代码

将要反编译的APK后缀名改为.rar或则 .zip,并解压,得到其中的额classes.dex文件(它就是java文件编译再通过dx工具打包而成的),将获取到的classes.dex放到之前解压出来的工具dex2jar-2.0 文件夹内,

在命令行下定位到dex2jar.bat所在目录,输入dex2jar.bat   classes.dex

高版本dex2jar的话,应该是d2j-dex2jar.bat classes.dex,效果如下:

(可以看到报了一些错,暂时未管它,退出可能dex2jar版本与apk不兼容或者jdk版本不兼容)

高版本dex2jar的话,还可以直接直接d2j-dex2jar.bat test-daiwei.apk,如下图

在改目录下会生成一个classes_dex2jar.jar的文件,然后打开工具jd-gui文件夹里的jd-gui.exe,之后用该工具打开之前生成的classes_dex2jar.jar文件,便可以看到源码了,效果如下:

附上所有工具包的下载地址:

apktool下载地址:https://ibotpeaches.github.io/Apktool/install/

dex2jar工具包:https://sourceforge.net/projects/dex2jar

jd-gui下载地址:http://jd.benow.ca/

如果以上都无法下载,你还可以从这里下载:https://download.youkuaiyun.com/download/wangchsh2008/11615913

如果你没有csdn积分而又非常需要它,那么请在评论区留言你的邮件,我会在有空的时候,发给你。

希望能帮助到有需要的程序员们!

 

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.youkuaiyun.com/zhouyuanjing/article/details/7446988]
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值