win32asm 全局钩子

本文详细介绍了如何使用win32汇编语言(asm)设置全局钩子。关键步骤包括将特定段设置为共享,以防止写时复制,并在Visual Studio链接器命令行中添加相关选项。此外,文章还提到了dll模块的构造,包括hookdll.asm、hookdll.inc头文件、hookdll.def导出文件,以及主程序的resource.h和rc资源文件。
摘要由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、付费专栏及课程。

余额充值