欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    WinIo详细使用说明.docx

    • 资源ID:24173969       资源大小:260.31KB        全文页数:30页
    • 资源格式: DOCX        下载积分:10金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    WinIo详细使用说明.docx

    1、WinIo详细使用说明WinIo详细使用说明(总18页)winio的使用WinIO程序库允许在32位的Windows应用程序中直接对I/O端口和物理内存进行存取操作。通过使用一种内核模式的设备驱动器和其它几种底层编程技巧,它绕过了Windows系统的保护机制。WinNT/2000/XP下,WinIO函数库只允许被具有管理者权限的应用程序调用。如果使用者不是以管理者的身份进入的,则不能够被安装,也不能激活WinIO驱动器。通过在管理者权限下安装驱动器软件就可以克服这种限制。然而,在这种情况下,ShutdownWinIo函数不能在应用程序结束之前被调用,因为该函数将WinIO驱动程序从系统注册表中

    2、删除。该函数库提供8个函数功能调用:bool _stdcall InitializeWinIo();本函数初始化WioIO函数库。必须在调用所有其它功能函数之前调用本函数。如果函数调用成功,返回值为非零值。如果调用失败,则返回值为0。 void _stdcall ShutdownWinIo();本函数在内存中清除WinIO库本函数必须在中止应用函数之前或者不再需要WinIO库时调用,bool _stdcall GetPortVal(WORD wPortAddr, PDWORD pdwPortVal, BYTE bSize);使用此函数从一个输入或输出端口读取一个字节/字/双字数据。参数:wPo

    3、rtAddr 输入输出端口地址pdwPortVal 指向双字变量的指针,接收从端口得到的数据。bSize 需要读的字节数,可以是1 (BYTE), 2 (WORD) or 4 (DWORD).如果调用成功,则返回非零值。如果函数调用失败,则函数返回值为零。 bool _stdcall SetPortVal(WORD wPortAddr, DWORD dwPortVal, BYTE bSize);使用本函数将一个字节/字/双字的数据写入输入或输出接口。参数:wPortAddr 输入输出口地址dwPortVal 要写入口的数据bSize 要写的数据个数,可以是 1 (BYTE), 2 (WORD)

    4、 or 4 (DWORD).如果调用成功,则返回非零值。如果函数调用失败,则函数返回值为零。 PBYTE _stdcall MapPhysToLin(PBYTE pbPhysAddr, DWORD dwPhysSize, HANDLE *pPhysicalMemoryHandle)使用此函数将物理内存的一部分映射到一个32位应用程序的线性地址空间。 下面是一个例子: PBYTE pbLinAddr;HANDLE PhysicalMemoryHandle;pbLinAddr = MapPhysToLin(0xA0000, 65536, &PhysicalMemoryHandle);该函数将把物理

    5、地址范围为0xA0000 - 0xAFFFF的地址空间映射到与应用程序对应的线性地址空间。 返回值为一个与物理地址0xA0000相关的线性地址。如果出现错误,则返回值为NULL。参数:pbPhysAddr 指向物理地址的指针dwPhysSize 需要映射的字节数pPhysicalMemoryHandle 变量指针,如果调用成功,负责接收物理内存句柄。随后本句柄在调用UnmapPhysicalMemory函数时作为其第一个参数。bool _stdcall UnmapPhysicalMemory(HANDLE PhysicalMemoryHandle, PBYTEpbLinAddr)使用本函数解除

    6、原先使用MapPhysToLin函数映射的一段线性物理内存区域,该区域被映射到应用程序所属的线性地址空间。Windows 9x 应用程序不需要调用此函数。参数:PhysicalMemoryHandle 物理内存区域所属的句柄,此参数由对MapPhysToLin函数的调用返回。pbLinAddr MapPhysToLin函数调用返回的线性地址。bool _stdcall GetPhysLong(PBYTE pbPhysAddr, PDWORD pdwPhysVal);从指定的物理地址读取一个双字数据。参数:pbPhysAddr 指向物理地址的指针。pdwPhysVal 指向一个双字变量的指针,接

    7、收从物理内存中传来的数据。如果此函数调用成功,返回一个非零值。如果函数调用失败,则返回一个零值。 bool _stdcall SetPhysLong(PBYTE pbPhysAddr, DWORD dwPhysVal);将一个双字型数据写入指定的物理地址。参数:pbPhysAddr 指向物理地址的指针。pdwPhysVal 指定待写入物理内存地址出的双字型数据。如果此函数调用成功,返回一个非零值。如果函数调用失败,则返回一个零值。VB winIO 模拟 键盘 外挂2007-01-12 01:05键盘是我们使用计算机的一个很重要的输入设备了,即使在鼠标大行其道的今天,很多程序依然离不开键盘来操作

    8、。但是有时候,一些重复性的,很繁琐的键盘操作总会让人疲惫,于是就有了用程序来代替人们按键的方法,这样可以把很多重复性的键盘操作交给程序来模拟,省了很多精力,按键精灵就是这样的一个软件。那么我们怎样才能用VB来写一个程序,达到与按键精灵类似的功能呢那就让我们来先了解一下windows中响应键盘事件的机制。 当用户按下键盘上的一个键时,键盘内的芯片会检测到这个动作,并把这个信号传送到计算机。如何区别是哪一个键被按下了呢键盘上的所有按键都有一个编码,称作键盘扫描码。当你按下一个键时,这个键的扫描码就被传给系统。扫描码是跟具体的硬件相关的,同一个键,在不同键盘上的扫描码有可能不同。键盘控制器就是将这个

    9、扫描码传给计算机,然后交给键盘驱动程序。键盘驱动程序会完成相关的工作,并把这个扫描码转换为键盘虚拟码。什么是虚拟码呢因为扫描码与硬件相关,不具有通用性,为了统一键盘上所有键的编码,于是就提出了虚拟码概念。无论什么键盘,同一个按键的虚拟码总是相同的,这样程序就可以识别了。简单点说,虚拟码就是我们经常可以看到的像VK_A,VK_B这样的常数,比如键A的虚拟码是65,写成16进制就是&H41,注意,人们经常用16进制来表示虚拟码。当键盘驱动程序把扫描码转换为虚拟码后,会把这个键盘操作的扫描码和虚拟码还有其它信息一起传递给操作系统。然后操作系统则会把这些信息封装在一个消息中,并把这个键盘消息插入到消息

    10、列队。最后,要是不出意外的话,这个键盘消息最终会被送到当前的活动窗口那里,活动窗口所在的应用程序接收到这个消息后,就知道键盘上哪个键被按下,也就可以决定该作出什么响应给用户了。这个过程可以简单的如下表示:用户按下按键-键盘驱动程序将此事件传递给操作系统-操作系统将键盘事件插入消息队列-键盘消息被发送到当前活动窗口明白了这个过程,我们就可以编程实现在其中的某个环节来模拟键盘操作了。在VB中,有多种方法可以实现键盘模拟,我们就介绍几种比较典型的。1.局部级模拟 从上面的流程可以看出,键盘事件是最终被送到活动窗口,然后才引起目标程序响应的。那么最直接的模拟方法就是:直接伪造一个键盘消息发给目标程序。

    11、哈哈,这实在是很简单,windows提供了几个这样的API函数可以实现直接向目标程序发送消息的功能,常用的有SendMessage和PostMessage,它们的区别是PostMessage函数直接把消息仍给目标程序就不管了,而SendMessage把消息发出去后,还要等待目标程序返回些什么东西才好。这里要注意的是,模拟键盘消息一定要用PostMessage函数才好,用SendMessage是不正确的(因为模拟键盘消息是不需要返回值的,不然目标程序会没反应),切记切记!PostMessage函数的VB声明如下:Declare Function PostMessage Lib user32 Al

    12、ias PostMessageA (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long参数hwnd 是你要发送消息的目标程序上某个控件的句柄,参数wMsg 是消息的类型,表示你要发送什么样的消息,最后wParam 和lParam 这两个参数是随消息附加的数据,具体内容要由消息决定。再来看看wMsg 这个参数,要模拟按键就靠这个了。键盘消息常用的有如下几个:WM_KEYDOWN 表示一个普通键被按下WM_KEYUP 表示一个普通键被释放WM_SYSKEYDOWN 表示一个系统键被

    13、按下,比如Alt键WM_SYSKEYUP 表示一个系统键被释放,比如Alt键如果你确定要发送以上几个键盘消息,那么再来看看如何确定键盘消息中的wParam 和lParam 这两个参数。在一个键盘消息中,wParam 参数的含义较简单,它表示你要发送的键盘事件的按键虚拟码,比如你要对目标程序模拟按下A键,那么wParam 参数的值就设为VK_A ,至于lParam 这个参数就比较复杂了,因为它包含了多个信息,一般可以把它设为0,但是如果你想要你的模拟更真实一些,那么建议你还是设置一下这个参数。那么我们就详细了解一下lParam 吧。lParam 是一个long类型的参数,它在内存中占4个字节,写

    14、成二进制就是00000000 00000000 00000000 00000000 一共是32位,我们从右向左数,假设最右边那位为第0位(注意是从0而不是从1开始计数),最左边的就是第31位,那么该参数的的0-15位表示键的发送次数等扩展信息,16-23位为按键的扫描码,24-31位表示是按下键还是释放键。大家一般习惯写成16进制的,那么就应该是&H00 00 00 00 ,第0-15位一般为&H0001,如果是按下键,那么24-31位为&H00,释放键则为&HC0,那么16-23位的扫描码怎么会得呢这需要用到一个API函数MapVirtualKey,这个函数可以将虚拟码转换为扫描码,或将扫描

    15、码转换为虚拟码,还可以把虚拟码转换为对应字符的ASCII码。它的VB声明如下:Declare Function MapVirtualKey Lib user32 Alias MapVirtualKeyA (ByVal wCode As Long, ByVal wMapType As Long) As Long参数wCode 表示待转换的码,参数wMapType 表示从什么转换为什么,如果是虚拟码转扫描码,则wMapType 设置为0,如果是虚拟扫描码转虚拟码,则wMapType 设置为1,如果是虚拟码转ASCII码,则wMapType 设置为2.相信有了这些,我们就可以构造键盘事件的lPara

    16、m参数了。下面给出一个构造lParam参数的函数:Declare Function MapVirtualKey Lib user32 Alias MapVirtualKeyA (ByVal wCode As Long, ByVal wMapType As Long) As LongFunction MakeKeyLparam(ByVal VirtualKey As Long, ByVal flag As Long) As Long参数VirtualKey表示按键虚拟码,flag表示是按下键还是释放键,用WM_KEYDOWN和WM_KEYUP这两个常数表示 Dim s As String Dim

    17、 Firstbyte As String lparam参数的24-31位 If flag = WM_KEYDOWN Then 如果是按下键 Firstbyte = 00 Else Firstbyte = C0 如果是释放键 End If Dim Scancode As Long 获得键的扫描码 Scancode = MapVirtualKey(VirtualKey, 0) Dim Secondbyte As String lparam参数的16-23位,即虚拟键扫描码 Secondbyte = Right(00 & Hex(Scancode), 2) s = Firstbyte & Secon

    18、dbyte & 0001 0001为lparam参数的0-15位,即发送次数和其它扩展信息 MakeKeyLparam = Val(&H & s)End Function这个函数像这样调用,比如按下A键,那么lParam=MakeKeyLparam(VK_A,WM_KEYDOWN) ,很简单吧。值得注意的是,即使你发送消息时设置了lParam参数的值,但是系统在传递消息时仍然可能会根据当时的情况重新设置该参数,那么目标程序收到的消息中lParam的值可能会和你发送时的有所不同。所以,如果你很懒的话,还是直接把它设为0吧,对大多数程序不会有影响的,呵呵。 好了,做完以上的事情,现在我们可以向目标

    19、程序发送键盘消息了。首先取得目标程序接受这个消息的控件的句柄,比如目标句柄是12345,那么我们来对目标模拟按下并释放A键,像这样:(为了简单起见,lParam这个参数就不构造了,直接传0)PostMessage 12345,WM_KEYDOWN,VK_A,0& 按下A键PostMessage 12345,WM_UP,VK_A,0& 释放A键好了,一次按键就完成了。现在你可以迫不及待的打开记事本做实验,先用FindWindowEx这类API函数找到记事本程序的句柄,再向它发送键盘消息,期望记事本里能诡异的自动出现字符。可是你马上就是失望了,咦,怎么一点反应也没有你欺骗感情啊555555 不是的

    20、哦,接着往下看啊。一般目标程序都会含有多个控件,并不是每个控件都会对键盘消息作出反应,只有把键盘消息发送给接受它的控件才会得到期望的反应。那记事本来说,它的编辑框其实是个edit类,只有这个控件才对键盘事件有反应,如果只是把消息发给记事本的窗体,那是没有用的。现在你找出记事本那个编辑框的句柄,比如是54321,那么写如下代码:PostMessage 54321,WM_KEYDOWN,VK_F1,0& 按下F1键PostMessage 54321,WM_UP,VK_F1,0& 释放F1键怎么样,是不是打开了记事本的“帮助”信息这说明目标程序已经收到了你发的消息,还不错吧可以马上新问题就来了,你想

    21、模拟向记事本按下A这个键,好在记事本里自动输入字符,可是,没有任何反应!这是怎么一回事呢原来,如果要向目标程序发送字符,光靠WM_KEYDOWN和WM_UP这两个事件还不行,还需要一个事件:WM_CHAR,这个消息表示一个字符,程序需靠它看来接受输入的字符。一般只有A,B,C等这样的按键才有WM_CHAR消息,别的键(比如方向键和功能键)是没有这个消息的,WM_CHAR消息一般发生在WM_KEYDOWN消息之后。WM_CHAR消息的lParam参数的含义与其它键盘消息一样,而它的wParam则表示相应字符的ASCII编码(可以输入中文的哦_),现在你可以写出一个完整的向记事本里自动写入字符的程

    22、序了,下面是一个例子,并附有这些消息常数的具体值:Declare Function PostMessage Lib user32 Alias PostMessageA (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As LongDeclare Function MapVirtualKey Lib user32 Alias MapVirtualKeyA (ByVal wCode As Long, ByVal wMapType As Long) As LongPublic Const WM

    23、_KEYDOWN = &H100Public Const WM_KEYUP = &H101Public Const WM_CHAR = &H102Public Const VK_A = &H41 Function MakeKeyLparam(ByVal VirtualKey As Long, ByVal flag As Long) As Long Dim s As String Dim Firstbyte As String lparam参数的24-31位 If flag = WM_KEYDOWN Then 如果是按下键 Firstbyte = 00 Else Firstbyte = C0 如

    24、果是释放键 End If Dim Scancode As Long 获得键的扫描码 Scancode = MapVirtualKey(VirtualKey, 0) Dim Secondbyte As String lparam参数的16-23位,即虚拟键扫描码 Secondbyte = Right(00 & Hex(Scancode), 2) s = Firstbyte & Secondbyte & 0001 0001为lparam参数的0-15位,即发送次数和其它扩展信息 MakeKeyLparam = Val(&H & s)End FunctionPrivate Sub Form_Load

    25、() dim hwnd as long hwnd = XXXXXX XXXXX表示记事本编辑框的句柄 PostMessage hwnd,WM_KEYDOWN,VK_A,MakeKeyLparam(VK_A,WM_KEYDOWN) 按下A键 PostMessage hwnd,WM_CHAR,ASC(A),MakeKeyLparam(VK_A,WM_KEYDOWN) 输入字符A PostMessage hwnd,WM_UP,VK_A,MakeKeyLparam(VK_A,WM_UP) 释放A键End Sub这就是通过局部键盘消息来模拟按键。这个方法有一个极大的好处,就是:它可以实现后台按键,也就是

    26、说他对你的前台操作不会有什么影响。比如,你可以用这个方法做个程序在游戏中模拟按键来不断地执行某些重复的操作,而你则一边喝茶一边与QQ上的MM们聊得火热,它丝毫不会影响你的前台操作。无论目标程序是否获得焦点都没有影响,这就是后台模拟按键的原理啦2.全局级模拟 你会发现,用上面的方法模拟按键并不是对所有程序都有效的,有的程序啊,你向它发了一大堆消息,可是它却一点反应也没有。这是怎么回事呢这就要看具体的情况了,有些程序(特别是一些游戏)出于某些原因,会禁止用户对它使用模拟按键程序,这个怎么实现呢比如可以在程序中检查一下,如果发现自己不是活动窗口,就不接受键盘消息。或者仔细检查一下收到的键盘消息,你会

    27、发现真实的按键和模拟的按键消息总是有一些小差别,从这些小差别上,目标程序就能判断出:这是假的!是伪造的!因此,如果用PostMessage发送局部消息模拟按键不成功的话,你可以试一试全局级的键盘消息,看看能不能骗过目标程序。模拟全局键盘消息常见的可以有以下一些方法:(1) 用API函数keybd_event,这个函数可以用来模拟一个键盘事件,它的VB声明为:Declare Sub keybd_event Lib user32 (ByVal bVk As Byte, ByVal bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As

    28、Long)参数bVk表示要模拟的按键的虚拟码,bScan表示该按键的扫描码(一般可以传0),dwFlags表示是按下键还是释放键(按下键为0,释放键为2),dwExtraInfo是扩展标志,一般没有用。比如要模拟按下A键,可以这样:Const KEYEVENTF_KEYUP = &H2keybd_event VK_A, 0, 0, 0 按下A键keybd_event VK_A, 0, KEYEVENTF_KEYUP, 0 释放A键注意有时候按键的速度不要太快,否则会出问题,可以用API函数Sleep来进行延时,声明如下:Declare Sub Sleep Lib kernel32 (ByVal

    29、 dwMilliseconds As Long)参数dwMilliseconds表示延时的时间,以毫秒为单位。那么如果要模拟按下功能键怎么做呢比如要按下Ctrl+C实现拷贝这个功能,可以这样:keybd_event VK_Ctrl, 0, 0, 0 按下Ctrl键keybd_event VK_C, 0, 0, 0 按下C键Sleep 500 延时500毫秒keybd_event VK_C, 0, KEYEVENTF_KEYUP, 0 释放C键keybd_event VK_Ctrl, 0, KEYEVENTF_KEYUP, 0 释放Ctrl键好了,现在你可以试试是不是可以骗过目标程序了,这个函数

    30、对大部分的窗口程序都有效,可是仍然有一部分游戏对它产生的键盘事件熟视无睹,这时候,你就要用上bScan这个参数了。一般的,bScan都传0,但是如果目标程序是一些DirectX游戏,那么你就需要正确使用这个参数传入扫描码,用了它可以产生正确的硬件事件消息,以被游戏识别。这样的话,就可以写成这样:keybd_event VK_A, MapVirtualKey(VK_A, 0), 0, 0 按下A键keybd_event VK_A, MapVirtualKey(VK_A, 0), KEYEVENTF_KEYUP, 0 释放A键以上就是用keybd_event函数来模拟键盘事件。除了这个函数,Sen

    31、dInput函数也可以模拟全局键盘事件。SendInput可以直接把一条消息插入到消息队列中,算是比较底层的了。它的VB声明如下:Declare Function SendInput Lib (ByVal nInputs As Long, pInputs As GENERALINPUT, ByVal cbSize As Long) As Long参数: nlnprts:定义plnputs指向的结构的数目。plnputs:指向INPUT结构数组的指针。每个结构代表插人到键盘或鼠标输入流中的一个事件。cbSize:定义INPUT结构的大小。若cbSize不是INPUT结构的大小,则函数调用失败。返回值:函数返回被成功地插人键盘或鼠标输入流中的事件的数目。若要获得更多的错误信息,可以调用GetlastError函数。备注:Sendlnput函数将INPUT结构中的事件顺序地插入键盘或鼠标的输入


    注意事项

    本文(WinIo详细使用说明.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开