当前位置:

把易语言源码修改为C++代码

xiaoming 2024-02-12 34 0

32dbg可以在重新载入程序后,还能断在DLL的0x1168偏移处,但是OD就死活断不下来。

现在我要让OD断下来,之前有大佬帮写过一个易语言源码的,当时并没有具体细看,而且不懂易语言。

今天试着把易语言版本的改成C++版本的,结果不成功,肯定是哪里没有写对。也不知道哪里有问题,

而且有一个地方是根本就看不明白。

.版本 2

    mem.写整数 (g_Pid, 进制_十六到十 (“4D8D70”), addr, 2)

    mem.写整数 (g_Pid, 进制_十六到十 (“4D8D78”), 1, 1)   类型

    mem.写整数 (g_Pid, 进制_十六到十 (“4D8D74”), 1, 1)

这一段根本就不明白到底是怎么回事,4D8D70,4D8D78,4D8D74从哪里来的?

如这一句,mem.写整数 (g_Pid, 进制_十六到十 (“4D8D70”), addr, 2)

最后一个参数是2,看帮助2代表是长整型,长整型是8个字节啊。 是不是不太合理?

1代表是整型,还能说得过去。

而且还有一个,就是这个源码在win7,win10上测试管用,但是在xp上是断不下来的,如何修复一下,

使其在xp,win7,win10上都管用?

里面有录像,可以看到在win7 x64虚拟机里成功了,在win10上也测试过了,也管用。

要说明的是:

必须使用吾爱OD,打包里已经提供。(针对本代码的话,估计必须要使用吾爱OD吧,如果原理搞懂了,改改代码改别的OD应该也一样)

(之前易语言提供者回复如下:)

那个PID就是吾爱OD的进程pid

测试的话,需要满足下面几个条件。

1.必须要吾爱的OD且这个版本建议是爱盘里面的OD

2.如果是win7,这个strongOD插件我记得会把进程隐藏了,记得先取消掉这个插件设置的内容,避免测试的时候可能会导致不必要的麻烦。

(不过经我测试,win7,win10都不用设置。XP上要把strongod去掉一下)

注意的是:

你测试过程中,请注意查看OD里面的硬断是否有正常写入,如果没有写入,可能是以下原因导致的:

1.OD版本不对

2.进程PID不对

链接:

https://cowtransfer.com/s/fb833c1274164a

发表评论

  • 评论列表
还没有人评论,快来抢沙发吧~
您是本站第9256名访客 今日有1篇新文章