开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 3537|回复: 23
收起左侧

[易源码分享] hook学习

[复制链接]
结帖率:100% (97/97)
发表于 2023-3-16 17:37:56 | 显示全部楼层 |阅读模式   四川省成都市
分享源码
界面截图:
是否带模块: -
备注说明: -
  
窗口程序集名保 留  保 留备 注
程序集1   
子程序名返回值类型公开备 注
_启动子程序整数型 请在本子程序中放置动态链接库初始化代码
hook ()
_临时子程序 ()  ' 在初始化代码执行完毕后调用测试代码
返回 (0)  ' 返回值被忽略。
子程序名返回值类型公开备 注
_临时子程序  
' 本名称子程序用作测试程序用,仅在开发及调试环境中有效,编译发布程序前将被系统自动清空,请将所有用作测试的临时代码放在本子程序中。 ***注意不要修改本子程序的名称、参数及返回值类型。
子程序名返回值类型公开备 注
hook 
变量名类 型静态数组备 注
hProcess整数型 
pfnhook整数型 
fnhook字节集 
lwlwcom 
modProcessMODULEENTRY320
i整数型 
hKernelUtil整数型 
hookaddr整数型 
hProcess = -1  ' 因为是注入 所以就是自身了
EnumModule (modProcess, 0)
计次循环首 (取数组下标 (modProcess, ), i)  ' 枚举出模块 选择我们需要改写的地址
如果真 (到文本 (modProcess [i].szModule)“KernelUtil.dll”)
hKernelUtil = modProcess [i].hModule
跳出循环 ()

计次循环尾 ()
hookaddr = hKernelUtil + HEX_to_DEC (“8336A”)
pfnhook = VirtualAlloc (0, 1024, #MEM_COMMIT, HEX_to_DEC ( #PAGE_EXECUTE_READWRITE ))  ' 申请一块内存 用于写入我们自己的汇编程序
lw.Initialize ()
lw.AsmAdd (“pushad”)
' ---------------函数1
lw.AsmAdd (“call ” + lw.AsmCallret (DEC_to_HEX (pfnhook + 1 - 1), DEC_to_HEX (取子程序地址 (&hook2))))  ' call我们的处理程序 call的地址 要根据申请内存和自己程序的地址 来计算偏移
lw.AsmAdd (“popad”)
lw.AsmAdd (“mov [ecx],eax”)  ' 这是我们修改的地方本身的操作,要给他保留回去 防止出错
lw.AsmAdd (“mov eax,[ebp+10]”)  ' 这是我们修改的地方本身的操作,要给他保留回去 防止出错
lw.AsmAdd (“ret”)  ' 我们只是读数据  所以要保留修改的地方的汇编代码
fnhook = HEX_to_Bytes (lw.AsmCode ())
WriteProcessMemory (hProcess, pfnhook, 取变量数据地址 (fnhook), 取字节集长度 (fnhook), 0)  ' 把我们的汇编代码写入刚刚申请的内存
lw.AsmClear ()
lw.AsmAdd (“call ” + lw.AsmCallret (DEC_to_HEX (hookaddr), DEC_to_HEX (pfnhook)))  ' 这里是我们要把hook 的地方 跳转到我们的函数 函数1 偏移自己算
fnhook = HEX_to_Bytes (lw.AsmCode ())
WriteProcessMemory (hProcess, hookaddr, 取变量数据地址 (fnhook), 取字节集长度 (fnhook), 0)  ' 把这段汇编 替换掉原来的汇编
子程序名返回值类型公开备 注
hook2 
变量名类 型静态数组备 注
EAX整数型 
EBX整数型 
EDX整数型 
置入代码 ({ 137, 69, 252, 137, 93, 248, 137, 85, 244 })  ' 这里就把 eax和ebx edx分别取出来了
' 我不知道为什么 如果把 打开文件写到这里的话,变量eax和变量ebx的值就变成空了。我也是新手不太理解 但是 如果是调用另一个子程序他就不会变
子程序1 (EAX, EBX, EDX)  ' 通过处理
返回 ()
子程序名返回值类型公开备 注
子程序1  
参数名类 型参考可空数组备 注
eax整数型
ebx整数型
edx整数型
变量名类 型静态数组备 注
a整数型 
如果真 (ebx = 5 eax ≠ 0 edx = HEX_to_DEC (“A0”))
a = 打开文件 (“C:\Users\asd\Desktop\log.txt”, 2, )
移到文件尾 (a)
如果 (eax < 0)
插入文本行 (a, “qqNUM:”到文本 (2147483647 × 2 + eax + 2))
插入文本行 (a, “qqNUM:”到文本 (eax))
关闭文件 (a)
返回 ()


i支持库列表   支持库注释   
spec特殊功能支持库


企鹅版本是9.7.3


我也是新手,正在学习这块方面。 不过我这个hook好像 每次收到消息 都会 显示两次发送者的id 我也不知道为啥。学习中,我想应该是经过了多次 可以自行替换模块修改,我这边就不提供我自己用的模块了。防止我的模块有毒.我弄的是注入的DLL 我自己测试没啥问题


学习.png
690MKZ36G5VZ5O6349WY.png

点评

hook2那里我知道为什么会变成空了。需要在植入代码之前先 让变量=0初始化。就不会变空   四川省成都市  发表于 2023-3-16 17:53

评分

参与人数 1好评 +1 精币 +2 收起 理由
qq1056123185 + 1 + 2 感谢大佬的分享,瞬间感觉QQ又行了~

查看全部评分


发表于 2023-5-11 14:05:11 | 显示全部楼层   黑龙江省牡丹江市
        支持开源~!感谢分享 必须支持一下
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)
发表于 2023-4-16 10:13:54 | 显示全部楼层   广东省东莞市
6666666666666666
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 2023-3-31 04:13:35 | 显示全部楼层   河北省衡水市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

签到天数: 11 天

发表于 2023-3-29 21:02:00 | 显示全部楼层   广东省惠州市
加油!努力学习!
回复 支持 反对

使用道具 举报

发表于 2023-3-28 05:54:01 | 显示全部楼层   浙江省金华市
        感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:92% (12/13)

签到天数: 2 天

发表于 2023-3-27 09:00:56 | 显示全部楼层   湖北省天门市
OK  谢谢了
回复 支持 反对

使用道具 举报

结帖率:92% (12/13)

签到天数: 2 天

发表于 2023-3-27 09:00:29 | 显示全部楼层   湖北省天门市
good6666666666
回复 支持 反对

使用道具 举报

签到天数: 12 天

发表于 2023-3-20 13:42:40 | 显示全部楼层   广西壮族自治区梧州市
支持开源
回复 支持 反对

使用道具 举报

结帖率:63% (5/8)
发表于 2023-3-18 22:29:16 | 显示全部楼层   内蒙古自治区乌兰察布市
更关心怎么定位的关键点
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表