前言
在学习的过程中需要借鉴优秀的程序,当然需要查看人家的源代码,这就提出了反编译。当遇到做的很好、有借鉴意义的软件时,总是忍不住要看看人家代码是怎么写的,是怎样做到这样强大的功能的,但往往我们并不知道软件是谁写的,也就没办法与软件作者进行沟通了,那是不是就没有办法达成我们学习进步的美好愿望呢?其实,办法是有的,软件反编译就是一个很好的办法,但这里笔者并不建议大家用这样的办法来盗版别人的软件,学习借鉴倒是可以的。
1.获得编写环境与语言
编程语言复杂性让我们的甄别性大大降低,我们只有知道目标软件是哪种编程语言和平台开发出来的,才能有的放矢的选择相应的反编译软件。此前查询到的PEiD是一款著名的查壳工具,其数量已超过470 种PE文档 的加壳类型和签名,另外还可识别出EXE文件是用什么语言编写的,比如:VC++、JAVA、VB或Delphi等。(照片暂时上传不上,稍后再补)
下载后直接点击自动就能运行,选取你要查询的EXE或其他,自动完成查询。
2.反汇编软件
通过软件获取编写语言,有了针对性,我们就能通过.NET Reflector(微软开发的环境下)在文件菜单中将需要反编译的DLL或EXE加载进来,.NET Reflector就会自动帮我们反编译,我们可以在.NET Reflector直接查看反编译后的源代码,也可以将源代码导出,具体操作步骤见下图
3.具体步骤:
查壳->脱壳、判断开发程序使用的环境->反编译->初步定位主要功能模块或函数的汇编指令起始、终止地址->反汇编准备->查找程序中的特征字符串或特征值,进一步确定需要反汇编的代码逻辑的位置->开始反汇编调试运行,分析需要反汇编的代码逻辑的具体过程->将分析出来的逻辑流程
4.学习优秀的软件,从开始的代码编写能了解到很多奇妙的思路,在我们茅塞的时候帮助我们找到新的方法,另辟蹊径的解决面临的困难。与其说是模仿、借鉴,庚来说是教授,通过一定的学习来不断提升。