Android开发:APK的反编译(获取代码和资源文件)

本文介绍了Android应用反编译的相关工具,包括APKTool用于反编译和回编译APK,dex2jar转换.dex到.jar,以及JD-GUI查看.jar文件。通过这些工具,开发者可以学习和研究APK内部结构,但要注意反编译主要用于学习目的,应避免非法使用。在反编译过程中可能会遇到错误,如ARSCDecoder错误,通常升级APKTool版本可解决。
摘要由CSDN通过智能技术生成

一、反编译工具:

  1、APKTool:

    APKTool是由GOOGLE提供的APK编译工具,能够完成反编译及回编译apk的工作。同时,它也有着安装反编译系统apk所需要的framework-res框架,以及清理以前反编译文件夹等功能。

    APKTool的使用需要java支持。

  2、dex2jar:

    dex2jar 是将android的.dex文件转换成Java的.class文件的转换工具,如果在转换过程中有问题的话,可以试用下其他的版本。

  3、jd-gui:

    JD分为JD-GUI、JD-Eclipse两种运行方式,JD-GUI是以单独的程序的方式运行,JD-Eclipse则是以一个Eclipse插件的方式运行。

    jd-gui只能查看,不能够将那些文件转换成.java文件。

  文件下载地址:https://pan.baidu.com/s/1ucFu7NATp0V3u9ixSwfnng

  提取码:eeir

二、APKTool使用:

  下载好的apktool文件夹中包含以下文件:aapt.exeapktool.batapktool.jarcmd.exe.

  

 

  1、反编译:

  将要反编译的apk文件复制到该文件夹下,打开cmd.exe,进入cmd中,执行命令:

 

apktool.bat d hotword.apk

  (不复制也行,但是执行命令时要使用绝对路径写清apk文件放置的精确位置)

  

  

  在apktool文件夹下可以看到hotword文件夹,里面存储的有res下的资源文件,和各种XML文件:

  

  

  

  如果你给定的apk反编译文件已经存在,那么输入完该命令后会提示你,并且无法执行,需要重新修改命令加入-f指令:

 

apktool.bat d –f hotword.apk

  这样会强行覆盖已经存在的文件。

  2、回编译:

  运行命令:

 

apktool.bat b hotword

  参数b代表回编译,hotword则是apk反编译出来的文件夹名。

  

  回编译完成会在hotword文件夹生成一个dist文件夹和一个build文件夹,dist文件夹里面存放的就是回编译后不带有签名的apk文件,build文件夹里面还有一个apk文件夹,里面存放的是回编译后没有打包成apk的文件。

  如下:

  

  

  

  3、安装特定的framework-res.apk文件:

  install-framework命令,应用于为APKTool安装特定的framework-res.apk文件,方便反编译一些与ROM相互依赖的APK文件。

三、dex2jar的使用:

  1、解压文件:

  将apk文件的后缀名改为zip格式,解压里面的classes.dex文件:

  

  

  将classes.dex放置到dex2jar文件夹下(或使用绝对路径),执行命令:

 

d2j-dex2jar.bat classes.dex

  

  得到一个jar包:

  

四、jd-gui的使用:

  打开jd-gui.exe:

  

  File-》open file···

  

  选中刚才生成的jar包,打开可得:

  

五、关于反编译:

  1、什么是反编译器 ?

  编译的定义是:将源代码转换成二进制执行代码的过程,将C源代码编译成exe可执行文件这样的就叫做编译。

  反编译:把二进制执行代码还原成源代码的过程,把exe转换为C源代码就叫反编译。  

  像Java、.net这样基于虚拟机技术的编程语言则反编译非常容易,Java平台下有JD等反编译器,.net平台下则有Reflector等反编译器。但是主流的C的编译器都进行了代码的优化,把C编译生成的exe文件反编译成C代码非常困难。

  2、反编译得到的是否是源代码?

   当然不是。

  代码与源代码是非常接近的,基本90%还原,但是还是会有一些差异。比如说,源代码里的a=2+3;这行代码,编译成apk再反编译回来,就变成了a=5;不会还原到2+3那种代码了。

  3、既然程序可以反编译,那是不是开发安卓程序很不安全,面临随时都会被破解的风险?

  这倒不至于,开发人员可以采用代码混淆等技术,以此来加大反编译的难度和降低反编译代码的可读性。

  但归根到底来说,不可能完全避免这种风险,不过可以大大减小,而且jd-gui只能查看,不能够将那些文件转换成.java文件。

六、问题解决:

  在apktool反编译的过程中可能出现如下错误:

  

  Exception in thread "main" brut.androlib.AndrolibException: Could not decode arsc file
    at brut.androlib.res.decoder.ARSCDecoder.decode(ARSCDecoder.java:54)
    at brut.androlib.res.AndrolibResources.getResPackagesFromApk(AndrolibResources.java:604)
    at brut.androlib.res.AndrolibResources.loadMainPkg(AndrolibResources.java:74)
    at brut.androlib.res.AndrolibResources.getResTable(AndrolibResources.java:66)
    at brut.androlib.Androlib.getResTable(Androlib.java:49)
    at brut.androlib.ApkDecoder.decode(ApkDecoder.java:93)
    at brut.apktool.Main.cmdDecode(Main.java:169)
    at brut.apktool.Main.main(Main.java:85)
  Caused by: java.io.IOException: Expected: 0x001c0001, got: 0x00000000
    at brut.util.ExtDataInput.skipCheckInt(ExtDataInput.java:48)
    at brut.androlib.res.decoder.StringBlock.read(StringBlock.java:43)
    at brut.androlib.res.decoder.ARSCDecoder.readPackage(ARSCDecoder.java:95)
    at brut.androlib.res.decoder.ARSCDecoder.readTable(ARSCDecoder.java:81)
    at brut.androlib.res.decoder.ARSCDecoder.decode(ARSCDecoder.java:49)
    ... 7 more

  这个报错的错因是:

  使用了新的adt,而反编译使用的apktool.jar的版本太低了,无法反编译某些apk,下载新的版本的apktool.jar并替换现在的版本即可。

  

  注:apk的反编译只可用于学习和研究,坚决不可随意修改他人代码,更加不可用作商用,望慎行!如有恶意行为,后果自负。

反编译工具包 下载后的操作步骤 Android APK反编译 未做测试全是最新工具包,另附已经做过测试的工具包,部分是旧工具,自己可替换 http://download.csdn.net/detail/haoqinghua/5500751 一、Apk反编译得到Java源代码 下载反编译工具包,打开apk2java目录下的dex2jar-0.0.9.9文件夹,内含apk反编译成java源码工具,以及源码查看工具。 dex2jar:apk反编译工具 ,是将apk中的classes.dex转化成jar文件 jdgui:源码查看工具,是一个反编译工具,可以直接查看反编译后的jar包源代码 具体步骤: 首先将apk文件后缀改为zip并解压,得到其中的classes.dex,它就是java文件编译再通过dx工具打包而成的,将classes.dex复制到dex2jar.bat所在目录dex2jar-0.0.9.9文件夹。 在命令行下定位到dex2jar.bat所在目录,运行 dex2jar.bat classes.dex 生成 classes_dex2jar.jar 然后,进入jdgui文件夹双击jd-gui.exe,打开上面生成的jar包classes_dex2jar.jar,即可看到源代码 二、apk反编译生成程序的源代码和图片、XML配置、语言源等文件 如果是汉化软件,这将特别有用 首先还是要下载此反编译工具包,其中包含最新的apktool 1.5 具体步骤: 下载反编译工具包,打开apk2java目录下的apktool1.4.1文件夹,内含三个文件:aapt.exe,apktool.bat,apktool.jar 注:里面的apktool_bk.jar是备份的老版本,最好用最新的apktool.jar 在命令行下定位到apktool.bat文件夹,输入以下命令:apktool.bat d -f abc123.apk abc123, apktool.bat 命令行解释:apktool.bat d -f [apk文件 ] [输出文件夹] 反编译的文件如下(AndroidManifest.xml为例): 将反编译完的文件重新打包成apk,很简单,输入apktool.bat b abc123(你编译出来文件夹)即可,命令如下: 打包apk后的文件在目录C:\HelloAndroid下,生成了两个文件夹: build dist 三、 图形化反编译apk 上述步骤一、二讲述了命令行反编译apk,现在提供一种图形化反编译工具:Androidfby 首先,下载上述反编译工具包,打开Androidfby目录,双击Android反编译工具.exe,就可以浏览打开要反编译apk
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值