开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 4052|回复: 8
收起左侧

[易语言纯源码] r3层下一种另类的hook方式 hookSyscall

[复制链接]
结帖率:100% (1/1)
发表于 2018-4-16 01:23:09 | 显示全部楼层 |阅读模式   广东省肇庆市
分享源码
界面截图: -
是否带模块: -
备注说明: -
以下代码是以hook OpenThread为例,如有不对的地方还请大神不吝赐教
hook SysCall应该是r3下比较底层的hook了,这种hook方式不是太多的杀软或者保护系统会去检测,暂时来说还是有一定的隐蔽性的

取得syscall的地址我是通过fs:[0xC0]获得的。

_按钮1_被单击的代码是测试用的,正常情况下,按下按钮整个窗口就会卡死,因为主线程被挂起了,hook之后按下了没反应

代码需要编译出来测试.基于我的系统编写的,不敢保证所有机器能用

mySysCall下的7个字节的nop是为了占位,因为我hook损坏的哪行代码是7个字节的。push 0x400000 retn是用来跳回原代码执行的。

  
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
setHook ()
子程序名返回值类型公开备 注
setHook  
变量名类 型静态数组备 注
sysCallAddr整数型 
oldCode字节集 
oldFlag整数型 
lenth整数型 
newCode字节集 
myFunJmpAddr整数型 
' 取得SysCall的地址
sysCallAddr = _getSysCallAddr ()
myOutPutDebugString (“sysCallAddr = 0x”取十六进制文本 (sysCallAddr))
' 计算我们hook要跳转的字节数
VirtualProtect (sysCallAddr, 5, #PAGE_EXECUTE_READWRITE, oldFlag)
oldCode = _读字节集 (sysCallAddr, 7)  ' 读取原始代码
lenth = _取真实地址 (&mySysCall) + 3 - sysCallAddr - 5
' 修改7个nop的位置为被我们损坏的代码
myFunJmpAddr = _取真实地址 (&mySysCall) + 3 + 7
VirtualProtect (myFunJmpAddr, 5, #PAGE_EXECUTE_READWRITE, oldFlag)
写到内存 (oldCode, myFunJmpAddr, )
' 修改要跳回的地址
myFunJmpAddr = _取真实地址 (&mySysCall) + 3 + 15
VirtualProtect (myFunJmpAddr, 5, #PAGE_EXECUTE_READWRITE, oldFlag)
写到内存 (到整数 (sysCallAddr + 7), myFunJmpAddr, )
' hook syscall
newCode = { 233 }到字节集 (lenth)
写到内存 (newCode, sysCallAddr, )
子程序名返回值类型公开备 注
mySysCall  
' _asm{
' cmp eax,0xFE
' je next
' nop
' nop
' nop
' nop
' nop
' nop
' nop
' push 0x400000
' retn
' next:
' add esp,0x4
' retn 0x10
' }
子程序名返回值类型公开备 注
_取真实地址整数型 
参数名类 型参考可空数组备 注
子程序指针子程序指针
变量名类 型静态数组备 注
返回值  
i整数型 
变量循环首 (到整数 (子程序指针), 到整数 (子程序指针) + 255, 1, i)
如果真 (指针到字节集 (i, 1){ 232 })  ' E8 call
返回值 = i + 取字节集数据 (指针到字节集 (i + 1, 4), #整数型, ) + 5
跳出循环 ()

变量循环尾 ()
返回 (返回值)
子程序名返回值类型公开备 注
_读字节集字节集 
参数名类 型参考可空数组备 注
内存地址整数型
读取长度整数型
变量名类 型静态数组备 注
变量字节集 
变量 = 取空白字节集 (读取长度)
置入代码 ({ 96, 139, 117, 8, 129, 254, 0, 0, 1, 0, 126, 27, 139, 93, 12, 139, 85, 252, 131, 194, 8, 191, 0, 0, 0, 0, 57, 251, 126, 9, 138, 4, 62, 136, 4, 58, 71, 235, 243, 97 })
' pushad
' mov esi,[ebp+0x8]
' cmp esi,0x10000
' jle Label1
' mov ebx,[ebp+0xC]
' mov edx,[ebp-0x4]
' add edx,0x8
' mov edi,0x0
' Label3:
' cmp ebx,edi
' jle Label2
' mov al,[esi+edi]
' mov [edx+edi],al
' inc edi
' jmp Label3
' Label2:
' Label1:
' popad
返回 (变量)
子程序名返回值类型公开备 注
_读整数型整数型 
参数名类 型参考可空数组备 注
Address整数型
置入代码 ({ 139, 77, 8, 139, 1, 139, 229, 93, 194, 4, 0 })
返回 (0)
子程序名返回值类型公开备 注
_getSysCallAddr整数型 
变量名类 型静态数组备 注
a整数型 
a = 0
置入代码 ({ 100, 161, 192, 0, 0, 0 })
' _asm:mov [ebp-0x4],eax
返回 (a)
子程序名返回值类型公开备 注
myOutPutDebugString  
参数名类 型参考可空数组备 注
str文本型
OutputDebugString (“[msg] ” + str)
子程序名返回值类型公开备 注
_按钮1_被单击  
变量名类 型静态数组备 注
hThread整数型 
hThread = OpenThread ( #THREAD_ALL_ACCESS, #NULL, GetCurrentThreadId ())
SuspendThread (hThread)
CloseHandle (hThread)


i支持库列表   支持库注释   
const(未知支持库)



补充内容 (2018-4-16 13:13):
52的也是我发的而已,不存在转载的问题

点评

转载的吾爱的   宁夏回族自治区银川市  发表于 2018-4-16 03:12
转载的最好带上出处!   重庆市重庆市  发表于 2018-4-16 02:10

结帖率:45% (10/22)

签到天数: 23 天

发表于 2018-5-3 00:07:02 | 显示全部楼层   辽宁省鞍山市
好深奥的样子!
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
发表于 2018-4-20 21:36:51 | 显示全部楼层   广东省深圳市
支持支持!!
回复 支持 反对

使用道具 举报

结帖率:100% (7/7)
发表于 2018-4-17 11:39:02 | 显示全部楼层   福建省泉州市
支持一下下~~~~
回复 支持 反对

使用道具 举报

结帖率:38% (3/8)
发表于 2018-4-16 05:09:06 | 显示全部楼层   河北省张家口市
完全看不懂!!!
回复 支持 反对

使用道具 举报

结帖率:82% (63/77)
发表于 2018-4-16 02:35:22 | 显示全部楼层   广东省茂名市
表示菜鸟看不懂
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 3 天

发表于 2018-4-16 01:33:21 | 显示全部楼层   广东省广州市
支持一下下~~~~
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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