大家好,又见面了,我是你们的朋友全栈君。
学习游戏辅助,根据郁金香的教学视频写了Dll注入的代码,针对热血江湖进行Dll注入,失败(通过360任务管理器查看到Dll并未注入到游戏进程中)。但Dll中的SetWindowsHookEx返回值不为空,说明Hook成功?但是为啥没有注入成功呢?已经在游戏进程敲击键盘了【通过键盘钩子来实现Hook的】
分析原因,先是反复检查代码,并未发现问题。
后面想起来,是否因为是Dll是32位,而游戏是64位?查看后发现Dll和游戏都是32位,不存在这个问题。
通过其他方式来验证,首先更换注入的目标进程,修改为计算器,发现Hook成功,但通过360任务管理器查看到Dll并未注入到计算器进程中。这时候发现计算器是64位的(win7系统自带)——疑问:Dll是32位,目标进程时64位,在Hook时,也会返回非NULL值??
更换目标进程为Potplayer播放器,这次终于成功,通过360任务管理器查看到Dll已注入到Potplayer进程中【注意:在用FindWindow函数时,传入的窗口名称不应该是简单的Potplayer,比如我的代码里填写的窗口名称就是:2.3.1.avi – Potplayer】
注入成功后,通过360任务管理器查看如下:
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/145341.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...