关于远程控制鼠标和键盘的那些事
在我们使用远程电脑控制软件时候,见得最多的除了画面,就是鼠标和键盘的操作了,那些远程控制的软件是如何工作的呢?经过与秒点远程控制工程师的深入交流,小编今天给大家讲讲其中原理。
其实远程控制软件的工作原理就是:A端操作,然后通过网络传输到B端,B端收到消息后做出相应的动作;然后动作的结果再通过画面形式传输回A端显示出来。今天我们就来讲讲鼠标和键盘在windows下远程控制的实现。有多种方法可以实现鼠标和键盘模拟,怎么用键盘代替鼠标点击,我们就介绍几种比较典型的。,
1、局部级模拟
但是,PostMessage这个方法发送消息,要事先知道对方的窗口句柄。要知道对方的窗口句柄就要使用到另外一函数,那就是FindWindow来查找目标窗口。HWND FindWindow(LPCTSTR lpClassName,LPCTSTR lpWindowName);这个方法FindWindow局限性比较大,就是要事先知道这个窗口的类名或者窗口名。在远程控制过程中我们要对不同的窗口做控制,而且还要知道这个窗口的信息才能有针对性的发消息才行。所以这不是一个很好的方案。这种方法以只适合做一些比较特别的动作。比如我们的窗口已经最小化到拖盘了,用户以为客户端还没启动,就会在桌面快捷方式中双击打开,但是我们程序又是不支持多开的,这种情况下,就用我们现在方法就可以解决这个问题。
HWND hwnd = FindWindow(null,&34;);
if (hwnd != NULL) {
PostMessage(hwnd,WM_SHOWWINDOW ,0,0)
SetForegroundWindow(hwnd);
}
当对方窗口收到消息的时候就可以做显示到前台了。
2、全局级模拟
比如mouse_event,keybd_event,SendInput,但是微软建议用SendInput代替另外两个,这里我们就讲讲SendInput举个例子,我们平时用的比较多的Win + D,可以快速切换到桌面。那这个一套按键是如何模拟的呢?
INPUT inputs[4] = {};
ZeroMemory(inputs,sizeof(inputs));
inputs[0].type = INPUT_KEYBOARD;åå
inputs[0].ki.wVk = VK_LWIN;
inputs[1].type = INPUT_KEYBOARD;
inputs[1].ki.wVk = VK_D;
inputs[2].type = INPUT_KEYBOARD;
inputs[2].ki.wVk = VK_D;
inputs[2].ki.dwFlags = KEYEVENTF_KEYUP;
inputs[3].type = INPUT_KEYBOARD;
inputs[3].ki.wVk = VK_LWIN;
inputs[3].ki.dwFlags = KEYEVENTF_KEYUP;
UINT uSent = SendInput(ARRAYSIZE(inputs),inputs,sizeof(INPUT));
if (uSent != ARRAYSIZE(inputs)) {
}
那我们秒点远控如何解决这个问题呢,那么就是我们接下来要讲的BOSS级的驱动级模拟了。
驱动级模拟
什么是驱动级模拟呢?首先,要普及一下设备驱动程序的知识了。
驱动程序一般指的是设备驱动程序(Device Driver),是一种可以使计算机和设备进行相互通信的特殊程序。相当于硬件的接口,操作系统只有通过这个接口,才能控制硬件设备的工作,假如某设备的驱动程序未能正确安装,便不能正常工作。因此,驱动程序被比作“ 硬件的灵魂”、“硬件的主宰”、“硬件和系统之间的桥梁”等。
在系统内核里面操作I/O端口,给连接键盘的集成电路发送指令,让它产生一个按下按键的信息,这样你的模拟输入对于所有程序来说就是从一个真实的设备发出的,而且可以绕过很多保护。从而达到模拟鼠标和键盘消息的输入事件。
我们在键盘上按下一个按键时,键盘会产生一个硬件中断,Windows会捕捉到这个中断,从而得知键盘上有了操作,然后由驱动来读取及处理键值。驱动程序的入口函数是
一、首先按下组合键“左Alt键”+“左Shift键”+“Num Lock键”开启鼠标键。二、按下组合键后,会弹出一个是否开启鼠标键的窗口,这时点击键盘上的“Y键”开启鼠标键。三、开启鼠标键后,观察通知栏上的鼠标键图标,若。
NTSTATUS DriverEntry(
IN PDRIVER_OBJECT DriverObject。
IN PUNICODE_STRING RegistryPath
)
里面主要的工作:
企业回工业键盘的使用环境和PC键盘有很大的不同,工业键盘因为要适应在各种不同的环境下使用,防护等级高,恶劣环境适应性更强。工业键盘带有电子锁开关,可防止非法开、关和非法键盘输入。防护防水等级为IP67,外观设计精美的工业键盘全密闭硅胶防水。
1、注册驱动卸载。
2、注册通用IRP分发。
四、开启鼠标键后就可以使用小键盘上的2、4、6、8四个键模拟鼠标上下左右移动,小键盘5键代替鼠标的左键,大键盘区域的菜单键代替鼠标右键,Pgup键和Pgdn键可代替鼠标滚轴进行上下滚动。
3、注册读取IRP分发。
4、注册电源IRP分发。
5、注册即插即用IRP分发。
6绑定设备。
键盘驱动对应着一条设备链,物理硬件(键盘)处于该设备链的最底端,在键盘上面叠着很多其他的虚拟设备,当键盘上有击键操作的时候,键值会存储在IRP中,所以我们可以创建一个虚拟的设备,绑定到这条设备链中来第一时间获取到按键信息,从而对其进行操作。
用键盘代替鼠标的方法是比较的简单,具体的方法步骤如下:1、首先打开电脑,在系统设置下找到控制面板并进入;2、进入“辅助功能”选项,点击“更改键盘的工作方式”;3、勾选“启用鼠标键”,再点击“设置鼠标键”;。
如果我们想对键盘的输入做一些改变,比如替换键值,就可以在第3步的时候读取键盘的输入值,并做相应的替换就行了。这个时候对于电脑操作系统看起来,传送过去的键盘鼠标信号,看起来都是物理的鼠标与键盘.