微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Windows – ToAscii / ToUnicode在键盘钩子中销毁死锁

看来如果在全局WH_KEYBOARD_LL钩子中调用ToAscii()或ToUnicode(),并且按下一个死键,它将被“销毁”.

例如,假设您已将Windows中的输入语言配置为西班牙语,并且要在程序中键入重音字母á.通常,您可以按单引号键(死键),然后按字母“a”,然后在屏幕上按照预期显示重音á.

但是,如果您在低级别的键盘挂接功能调用ToAscii()或ToUnicode(),则此功能无效.看来死钥匙被毁了,所以没有重音字母á显示在屏幕上.删除对上述功能调用解决了问题…但不幸的是,我需要能够调用这些功能.

我已经Google Googled了一段时间,而很多人似乎都有这个问题,没有提供好的解决方案.

任何帮助将不胜感激!

编辑:我正在调用ToAscii()将我的LowLevelKeyboardProc挂钩功能中接收到的虚拟键代码和扫描代码转换用户显示在屏幕上的结果字符.

我尝试MapVirtualKey(kbHookData-> vkCode,2),但这不像ToAscii()一样完整的函数;例如,如果您按Shift 2,您将获得’2′,而不是’@'(或Shift 2将为用户键盘布局/语言产生的任何东西).

ToAscii()是完美的,直到一个死键被按下.

EDIT2:这是钩子功能,删除不相关的信息:

LRESULT CALLBACK keyboard_LL_hook_func(int code,WParaM wParam,LParaM lParam) {

    LPKBDLLHOOKSTRUCT kbHookData = (LPKBDLLHOOKSTRUCT)lParam;
    BYTE keyboard_state[256];

    if (code < 0) {
        return CallNextHookEx(keyHook,code,wParam,lParam);
    }

    WORD wCharacter = 0;

    GetKeyboardState(&keyboard_state);
    int ta = ToAscii((UINT)kbHookData->vkCode,kbHookData->scanCode,keyboard_state,&wCharacter,0);

    /* If ta == -1,a dead-key was pressed. The dead-key will be "destroyed"
     * and you'll no longer be able to create any accented characters. Remove
     * the call to ToAscii() above,and you can then create accented characters. */

    return CallNextHookEx(keyHook,lParam);
}
>停止使用ToAscii()并使用ToUncode()
>记住,ToUnicode可能会在死钥匙上返回任何东西 – 这就是为什么它们被称为死钥匙.
>任何键都有一个扫描码或虚拟键码,但不需要一个字符.

您不应该将按钮与字符组合 – 假设任何键/按钮都有文本表示(Unicode)是错误的.

所以:

>输入文本使用Windows报告的字符>用于检查按钮(例如游戏)使用扫描码或虚拟键(可能虚拟键更好).>键盘快捷键使用虚拟键码.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Windows注册表操作基础代码 Windows下对注册表进行操作使用的一段基础代码Reg.h:#pragmaonce#include&lt;assert.h&gt;#include&lt;windows.h&gt;classReg{HKEYhkey;public:voidopen(HKEYroot
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的内容,在Windows环境下的黑客必须熟练掌握底层API编程。为了使读者对黑客常用的Windows API有个更全面的了解以及方便日后使用API方法的查询,特将这些常用的API按照7大分类进行整理如下,希望对大家的学习有所帮助。一
一个简单的Windows Socket可复用框架说起网络编程,无非是建立连接,发送数据,接收数据,关闭连接。曾经学习网络编程的时候用Java写了一些小的聊天程序,Java对网络接口函数的封装还是很简单实用的,但是在Windows下网络编程使用的Socket就显得稍微有点繁琐。这里介绍一个自己封装的一
Windows文件操作基础代码 Windows下对文件进行操作使用的一段基础代码File.h,首先是File类定义:#pragmaonce#include&lt;Windows.h&gt;#include&lt;assert.h&gt;classFile{HANDLEhFile;//文件句柄publ
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要的一段代码:#include&lt;PCAP.H&gt;#pragmacomment(lib,&quot;wpcap.lib&quot;)//#pragmacomment(lib,&quot;ws2_32.lib&quot;)#
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312。系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsigh...
缓冲区溢出攻击缓冲区溢出(Buffer Overflow)是计算机安全领域内既经典而又古老的话题。随着计算机系统安全性的加强,传统的缓冲区溢出攻击方式可能变得不再奏效,相应的介绍缓冲区溢出原理的资料也变得“大众化”起来。其中看雪的《0day安全:软件漏洞分析技术》一书将缓冲区溢出攻击的原理阐述得简洁
Windows字符集的统一与转换一、字符集的历史渊源在Windows编程时经常会遇到编码转换的问题,一直以来让刚接触的人摸不着头脑。其实只要弄清Win32程序使用的字符编码方式就清楚了,图1展示了一个Win32控制台项目的属性中的字符集选项。这里有两个不同的字符集:一个是Unicode字符集,另一个
远程线程注入引出的问题一、远程线程注入基本原理远程线程注入——相信对Windows底层编程和系统安全熟悉的人并不陌生,其主要核心在于一个Windows API函数CreateRemoteThread,通过它可以在另外一个进程中注入一个线程并执行。在提供便利的同时,正是因为如此,使得系统内部出现了安全
windows系统启动项怎么打开