反编译及JD-GUI 使用详解

1、反编译介绍

1.1、 什么是反编译器

大家都知道,将源代码转换成二进制执行代码的过程叫“编译”,比如将C源代码编译成exe可执行文件;那么把二进制执行代码转换成源代码的过程就叫“反编译”,比如把exe转换为C源代码就叫“反编译”。

由于主流的C的编译器都进行了代码的优化,因此把C编译生成的exe文件反编译成C代码非常困难。但是像Java、.net这样基于虚拟机技术的编程语言则反编译非常容易,Java平台下有Jad、Jode、JD等反编译器,.net平台下则有Reflector等反编译器,反编译质量非常高,甚至和源代码几乎没什么差别。

1.2、 反编译得到的是源代码吗?

反编译得到的代码是非常接近于源代码,但是或多或少与源代码有一些差异的,比如一些表达式被优化掉了,比如: 下面的源代码: int i=1+1;
学过《编译原理》的同学知道有“常量优化”这个编译优化算法,因此上边的源代码一般会被优化为:int i=2;
 由于在编译过程中已经进行了优化,把“1+1”这个原始的信息丢掉了,因此反编译出来的代码只能是: int i=2;
 可以看到反编译得到的代码和源代码是有区别的。 
 比如:andriod中 download =(Button)findViewById(R.id.xiaz); 被优化成了download =
(Button)findViewById(0x7f070018

 1.3、程序可以反编译岂不是很不安全?

可以采用代码混淆等技术来加大反编译的难度和降低反编译代码的可读性,但是完全避免反编译是不可能的。

1.4、 反编译器的原理是什么?

由于Java、.net这样的基于虚拟机技术的语言都是采用了ByteCode的二进制结构,因此很容易将ByteCode转化为“抽象语法树”(简称AST,《编译原理》这门课中的概念),然后采用反编译器就可以将AST转换为代码了。

2、 JD-GUI 介绍

《JD-GUI》是一款反编译软件,JD分为JD-GUI、JD-Eclipse两种运行方式,JD-GUI是以单独的程序的方式运行,JD-Eclipse则是以一个Eclipse插件的方式运行

2.1、下载软件

www.pc6.com/mac/152875.html?source=1

2.2、安装软件

如果打不开:解压安装包,info.plist里面 1.8+ 调整为1.8

2.3、软件使用

解压java 打包好的war包或者jar包 打开方式一:

反编译及JD-GUI 使用详解_第1张图片
选择对应的class 文件即可

打开方式二: 将class 文件直接拖动到软件的界面处即可打开

你可能感兴趣的:(java-必备技能,python,pycharm,开发语言)