安卓APK的反编译理解
? 一般意义上的编程过程可以理解为将我们使用的代码语言(属性和指令), 编译成机器可以识别的机器语言, 然后机器进行执行. ? 在Java中 #编译 的过程是将代码转换成Java虚拟机可以识别的语言, 再由虚拟机完成编译给机器的工作, 理解了这一步, 我们就可以开始安卓app的反编译了. ? 需要注意的是, 反编译是为了举一反三, 取长补短, 学习为主, 强抢为辅.
软件的安装过程
? 软件的安装简单的可以理解为将需要的文件和数据拷贝到你要使用的机器中, 并集合成执行文件的形态, 方便用户使用. 这里不对安卓APK具体的安装过程做详细分析, 需要了解的小伙伴可以自主学习. ? 为了方便理解, 我们可以这样解释这个过程. 熟悉Window软件安装的小伙伴应该知道, Windows 软件安装包大都是一个后缀为 exe 的文件, 执行安装后会在电脑内产生一个软件文件夹. 如果这个 exe 文件是用 Java 语言开发的, 那他就经历了源文件(.java), 编译器编译 (javac.exe) 生成字节码(.class), 通常情况下字节码可以直接被 java 解释器 (java.exe) 直接执行, 但这种执行方式只能在有 Java 环境的电脑里使用. ? 于是, 我们通过生成包 ( .jar) 文件 (可以理解为把软件需要用到的类也就是字节码(class)打包), 再将这个包转化成我们使用环境需要的执行文件(比如.exe, apk), 软件就可以在别的环境下使用了.
反编译的过程
? 理解了生成 exe 文件的过程, 那么反编译 APK 也就不难理解, 只需将 apk 文件反编译成包(.jar), 然后再将包拆解成类(.class), 类文件可以直接通过优秀的反编译工具 jd-gui 直接读出源代码(.java), 至此, 工作完成. (至于为什么可以直接读出源码, 可以深入了解一下 Java 虚拟机的机制, 这里就不做介绍了) ? 软件分为代码和资源, 获取资源也是重要的步骤
反编译工具和反编译操作
朱玉在前, 我就不重复介绍了, 可以看这两篇文章:
Android反编译三件套 apktool 、dex2jar、jd-gui
Android APK反编译就这么简单 详解
反’反编译’
? 有的软件设计者因为珍惜自己的工作, 做了代码混淆来组织反编译, 这部分内容还需要深入学习.
|