利用VB建立鼠标键盘操作回放

上传人:二*** 文档编号:57268674 上传时间:2022-02-23 格式:DOC 页数:5 大小:43.50KB
返回 下载 相关 举报
利用VB建立鼠标键盘操作回放_第1页
第1页 / 共5页
利用VB建立鼠标键盘操作回放_第2页
第2页 / 共5页
利用VB建立鼠标键盘操作回放_第3页
第3页 / 共5页
点击查看更多>>
资源描述
利用VB建立鼠标键盘操作回放 很多的教学软件或系统监视软件可以自动记录回放用户的输入文字或点击按钮等操作操作,这个功能的实现是使用了Windows的Hook函数。本文介绍如何通过使用VB来实现鼠标键盘操作的纪录和回放。 Windows提供API函数SetwindowsHookEx来建立一个Hook,通过这个函数可以将一个程序添加到Hook链中监视Windows消息,函数语法为: Public Declare Function SetWindowsHookEx Lib user32 _ Alias SetWindowsHookExA _ (ByVal idHook As Long, _ ByVal lpfn As Long, _ ByVal hmod As Long, _ ByVal dwThreadId As Long) As Long 其中参数idHook指定建立的监视函数类型。通过Windows MSDN帮助可以看到,SetwindowsHookEx函数提供15种不同的消息监视类型,在这里我们将使用WH_JOURNALRECORD和WH_JOURNALPLAYBACK来监视键盘和鼠标操作。参数lpfn指定消息函数,在相应的消息产生后,系统会调用该函数并将消息值传递给该函数供处理。函数的一般形式为: Hookproc (code: Integer; wparam: WPARAM; lparam: LPARAM): LRESULT stdcall; 其中code为系统指示标记,wParam和lParam为附加参数,根据不同的消息监视类型而不同。只要在程序中建立这样一个函数再通过SetwindowsHookEx函数将它加入到消息监视链中就可以处理消息了。 在不需要监视系统消息时需要调用提供UnHookWindowsHookEx来解除对消息的监视。 WH_JOURNALRECORD和WH_JOURNALPLAYBACK类型是两种相反的Hook类型,前者获得鼠标、键盘动作消息,后者回放鼠标键盘消息。所以在程序中我们需要建立两个消息函数,一个用于纪录鼠标键盘操作并保存到一个数组中,另一个用于将保存的操作返给系统回放。 下面是具体的程序实现:首先建立一个新工程,在Form1中加入三个CommandButton控件用于控制消息钩子,另外还可以增加若干Command或者TextBox控件用于检验操作回放的效果。然后在工程中增加一个模块文件,在模块中加入以下定义和代码:Option ExplicitPublic Type EVENTMSG message As Long paramL As Long paramH As Long time As Long hwnd As LongEnd TypePublic Declare Function CallNextHookEx Lib user32 _ (ByVal hHook As Long, _ ByVal ncode As Long, _ ByVal wParam As Long, _ ByVal lParam As Long) As LongPublic Declare Function SetWindowsHookEx Lib user32 _ Alias SetWindowsHookExA _ (ByVal idHook As Long, _ ByVal lpfn As Long, _ ByVal hmod As Long, _ ByVal dwThreadId As Long) As LongPublic Declare Sub CopyMemoryT2H Lib kernel32 _ Alias RtlMoveMemory _ (ByVal Dest As Long, _ Source As EVENTMSG, _ ByVal Length As Long)Public Declare Sub CopyMemoryH2T Lib kernel32 _ Alias RtlMoveMemory _ (Dest As EVENTMSG, _ ByVal Source As Long, _ ByVal Length As Long)Public Declare Function UnhookWindowsHookEx Lib user32 _ (ByVal hHook As Long) As LongPublic Const WH_JOURNALPLAYBACK = 1Public Const WH_JOURNALRECORD = 0Public Const HC_SYSMODALOFF = 5Public Const HC_SYSMODALON = 4Public Const HC_SKIP = 2Public Const HC_GETNEXT = 1Public Const HC_ACTION = 0Public EventArr(1000) As EVENTMSGPublic EventLog As LongPublic PlayLog As LongPublic hHook As LongPublic hPlay As LongPublic recOK As LongPublic canPlay As LongPublic bDelay As BooleanPublic Function HookProc(ByVal iCode As Long, ByVal wParam As Long, _ ByVal lParam As Long) As Long Dim Result As Long recOK = 1 Result = 0 If iCode 0) And (iCode = HC_ACTION) Then 将消息纪录在纪录队列中 CopyMemoryH2T EventArr(EventLog), lParam, Len(EventArr(EventLog) EventLog = EventLog + 1 If EventLog = 1000 Then 当纪录大于1000后释放消息钩子 UnhookWindowsHookEx hHook End If End If HookProc = ResultEnd FunctionPublic Function PlaybackProc(ByVal iCode As Long, ByVal wParam As Long, _ ByVal lParam As Long) As Long Dim Result As Long canPlay = 1 Result = 0 If iCode = EventLog Then UnhookWindowsHookEx hPlay End If PlaybackProc = ResultEnd Function 在Form1的代码窗口中加入以下代码:Option ExplicitPrivate Sub Command1_Click() EventLog = 0 hHook = SetWindowsHookEx(WH_JOURNALRECORD, AddressOf HookProc, _ App.hInstance, 0) Command2.Enabled = True Command1.Enabled = FalseEnd SubPrivate Sub Command2_Click() UnhookWindowsHookEx hHook hHook = 0 Command1.Enabled = True Command2.Enabled = False Command3.Enabled = TrueEnd SubPrivate Sub Command3_Click() PlayLog = 0 hPlay = SetWindowsHookEx(WH_JOURNALPLAYBACK, AddressOf PlaybackProc, _ App.hInstance, 0) Command3.Enabled = FalseEnd SubPrivate Sub Form_Load() Command1.Caption = 纪录 Command2.Caption = 停止 Command3.Caption = 回放 Command2.Enabled = False Command3.Enabled = FalseEnd Sub 运行程序,点击“纪录”按钮,然后在TextBox中输入一些文字或者在窗口上移动光标后再按“停止”键停止消息纪录,然后按“回放”按钮,可以看到刚才鼠标键盘的操作被丝毫不差的回放了出来。 从上面的程序可以看到:通过WH_JOURNALRECORD可以建立一个鼠标键盘消息钩子,当每一个鼠标键盘消息产生时被钩子函数被调用。在钩子函数中可以将消息保存在消息事件队列中。然后通过WH_JOURNALPLAYBACK建立消息回放钩子,当每一次系统可以回放消息时就会调用钩子函数,在钩子函数中就可以从消息队列中取出原来纪录的消息返回给系统。这样就实现了鼠标键盘操作的纪录和回放。 上面的程序在VB6下编写,在Win98、Win2K下编译运行通过。
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 商业管理 > 营销创新


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!