举个例子:
比如在 VB6 中有一句代码 : MsgBox "Decompile Test."
那么反编译出来的结果就是:
(代码太长不贴,这里贴主要的)
...
mov dword ptr [ebp-58], 004012E4 这里把 "Decompile Test."的地址弄进去了。
...
call dword ptr [<&MSVBVM60.__vbaVarDup>]可以清楚的看做模出来,复制了一份变量的句柄。因为VB里字符串指向的是内存地址。
...
call dword ptr [<&MSVBVM60.#595>] 这一句d出了MsgBox.这里如果跟进去的话是一大堆API 。
...
所以正常反编译(学汇编语言和计算机编译原理去吧)的话,看到段了就会知道这是一个 Msgbox 函数,但是具体显示的内容是什么,那是根本看不出来的。
P.S. 针对楼上[你不懂就别乱说]说的插一嘴,未加纯举缓壳的 .NET 为何能被反编译出源代码,那是因为 .NET 是托管,而托管有中间语言,所以它的源代码被编译成 msil 这种中间语言而非像 VB6 直接编译成机器语言了。
不可以的,已经转郑备兄换为了机器指令,不能恢复为源程序的有滚斗的反编译软件,其实只能恢复标准控件的语句,实际的用户写的根本无法恢复。
只能用vbexplorer之类的软件查看资源,查看窗体之类的
代码是看不到的
要修改一个exe程序
就涉及到反汇编了
一般都是软件OD(全称:OllyDBG)
不过必须要求你有汇编语言的基础才行
VB反编译精灵也可以,但是好像不可喊袭以用
真正反编译是不可能的,不管是P代码还是本机代码,不加壳也反编译不了,至于什么.net反编译,更是痴人说梦!网上虽有一些反编译神源软件,但是顶多把你用了哪些控件找出来逗瞎斗,至山磨于代码就无能为力了欢迎分享,转载请注明来源:内存溢出
评论列表(0条)