开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 11454|回复: 49
收起左侧

[源码分享] VB钩子制作 ---- 输入法与键盘HOOK

[复制链接]

结帖率:100% (2/2)
发表于 2011-11-6 19:25:53 | 显示全部楼层 |阅读模式   广东省肇庆市
本帖最后由 易团颜 于 2011-11-6 19:26 编辑

截图1320573088.png
----------------------------------------------------------
截图1320573012.png
------------------------------------------------------------
截图1320572988.png
----------------------------------------------------------
截图1320572905.png
==============================
拦截并修改输入法,就是说比如你用智能ABC输入法,输入法文字是“一二三”,但是确认上屏后出来的内容确是“四五六”这样子,此技术大概可以用来做输入法辅助辅助工具之类的吧。
模块是一个DLL,用VC++写的,压缩包里有这个DLL的源码。原理就是使用API HOOK拦截输入法的相关函数(ImmGetCompositionString函数,应用程序通过调用这个函数取得输入法输入),以达到截获并修改输入信息的目的。
VB也可以使用这个DLL,DLL通过自定义消息WM_HXWDLLWX_QQBTX与主程序通信。要在VB里处理自定义消息可能您需要用到子类化技术。
该DLL导出如下函数:
Public Declare Function DLLstartHOOK Lib "hxwdllwx.dll" (ByVal hwnd As Long) As Long
Public Declare Function DLLstopHOOK Lib "hxwdllwx.dll" () As Long
Public Declare Function DLLsetHOOKState Lib "hxwdllwx.dll" (ByVal myState As Boolean) As Long
Public Declare Function DLLGetPubString Lib "hxwdllwx.dll" () As String
Public Declare Function DLLSetPubString Lib "hxwdllwx.dll" (ByVal tmpstr As String) As Long
简单的说下怎么用:
在窗体的Load事件中,你需要注册自定义消息WM_HXWDLLWX_QQBTX,然后调用DLLstartHOOK函数初始化拦截模块,你需要将程序窗口的句柄传递给DLLstartHOOK函数,这样,当用户输入事件发生时,DLL会发送WM_HXWDLLWX_QQBTX消息给该句柄的窗口。该窗口为了能处理自定义消息,需要先子类化。如下所示:
Private Sub Form_Load()
WM_HXWDLLWX_QQBTX = RegisterWindowMessage("WM_HXWDLLWX_QQBTX")  '注册自定义消息
DLLstartHOOK Me.hwnd  '初始化输入法拦截模块
PrevWndProc = SetWindowLong(Me.hwnd, GWL_WNDPROC, AddressOf SubWndProc) '子类化窗口
End Sub
然后就可以调用DLLsetHOOKState函数来设置拦截模块的状态,DLLsetHOOKState True打开拦截,DLLsetHOOKState False关闭拦截。
在打开拦截的情况下,一旦用户发生输入事件,DLL会发送自定义消息WM_HXWDLLWX_QQBTX给主窗口,在主窗口处理WM_HXWDLLWX_QQBTX消息的函数中,可以调用DLLGetPubString函数得到用户的输入。如果需要修改用户的输入,可以调用DLLSetPubString函数重新设置用户的输入,这样就可以修改输入法内容了。如下所示,下面的代码将用户的每一次输入都自动添加字符串“END”,比如用户输入“你好”,出来的是“你好END”。
Public Function SubWndProc(ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Dim myConStr As String, tmpStr1 As String, tmpStr2 As String
If Msg = WM_HXWDLLWX_QQBTX Then
   myConStr = DLLGetPubString()
   tmpStr1 = Replace(myConStr, Chr(0), "")
   tmpStr2 = myconver(tmpStr1)
   DLLSetPubString tmpStr2
End If
SubWndProc = CallWindowProc(PrevWndProc, hwnd, Msg, wParam, lParam)
End Function
Function myconver(ByVal s As String) As String
myconver = s & "END"
End Function
最后,程序结束的时候别忘了调用DLLstopHOOK卸载这个API HOOK。
基本上就是这样了,压缩包中给出了完整的示例代码,并且还有一个应用的例子。
源码回复后、免费下载
源码分卷附件1下载: 输入法与键盘HOOKp[源码].part1.rar (781.25 KB, 下载次数: 121)

评分

参与人数 1好评 +1 精币 +5 收起 理由
ノ朽默℡ + 1 + 5 奉上小小红包希望笑纳

查看全部评分

结帖率:37% (7/19)
发表于 2011-11-6 19:26:48 | 显示全部楼层   北京市北京市
分享精神值得支持
回复 支持 反对

使用道具 举报

发表于 2011-11-6 20:30:11 | 显示全部楼层   内蒙古自治区通辽市
值得评分!{:3_245:}
回复 支持 反对

使用道具 举报

发表于 2011-11-6 20:32:05 | 显示全部楼层   内蒙古自治区通辽市
两个下载点= ={:3_230:}{:3_229:}
回复 支持 反对

使用道具 举报

发表于 2011-11-6 20:34:17 | 显示全部楼层   内蒙古自治区通辽市
大哥!看不懂啊{:3_227:}
回复 支持 反对

使用道具 举报

发表于 2011-11-7 04:40:04 | 显示全部楼层   江苏省淮安市
分享精神值得支持{:3_244:}
回复 支持 反对

使用道具 举报

发表于 2011-11-14 17:02:45 | 显示全部楼层   新疆维吾尔自治区巴音郭楞蒙古自治州
     RE: VB钩子制作 ---- 输入法与键盘HOOK [修改]  
回复 支持 反对

使用道具 举报

发表于 2011-12-18 16:15:15 | 显示全部楼层   浙江省丽水市
看看,支持下楼主
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 1 天

发表于 2011-12-26 17:20:07 | 显示全部楼层   广东省惠州市
滴答滴答滴答滴答滴答滴答滴答滴答滴答滴答滴答滴
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)
发表于 2012-1-3 11:46:45 | 显示全部楼层   山东省潍坊市
{:3_232:}强大!{:soso__10868261115054587459_1:}
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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