win32asm 全局钩子

反编译用.data? 设置成共享段, 否则触发写时复制在vs 链接器的命令行中加入/section:.bss,S .dll 模块hookdll.asm.386.model flat, stdcalloption casemap:noneinclude windows.incinclude user32.incincludelib user32.libinclude kernel32.incincludelib kernel32.lib...
摘要由CSDN通过智能技术生成

 

反编译用

.data?  设置成共享段, 否则触发写时复制 

在vs 链接器的命令行中加入  /section:.bss,S .  

 

dll 模块

hookdll.asm

.386
.model flat, stdcall
option casemap:none

include		windows.inc
include		user32.inc
includelib	user32.lib
include		kernel32.inc
includelib	kernel32.lib



.data
hModule dd ?

.data?
hWnd dd ?
hHook dd ?
dwMsg dd ?
szMsg db 256 dup (?)  ; 设置成共享段,否则write on copy 

.code
DLLMain proc instance,dwReason,dwReserved
	.if dwReason == DLL_PROCESS_ATTACH
		push instance
		pop hModule
	.endif
	
	mov eax,TRUE
	ret
DLLMain endp

hook_proc	proc uses edx, code,wp,lp
	
	mov edx,lp
	and edx,40000000h

	.if code < 0 || code ==  HC_NOREMOVE ||  edx
		invoke CallNextHookEx, hHook, code, wp, lp
		ret
	.endif		

	invoke GetKeyNameTextA,lp,addr szMsg, sizeof szMsg
	invoke	SendMessage,hWnd,dwMsg,addr szMsg,NULL

	invoke CallNextHookEx, hHook, code, wp, lp
	ret
hook_proc endp



install_hook proc sendToThisHWND, 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值