欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【关于在IE下的一个安全BUG --可用于跟踪用户的系统鼠标位置】,下面是详细的讲解!
关于在IE下的一个安全BUG --可用于跟踪用户的系统鼠标位置
IE下的DHTML有各种MS$的私有特征,已经是众所周知。其中有个比较有趣就是:event.screenX和event.screenY,可以获得系统级别的鼠标位置坐标。
咋一听,其实也觉得没什么。屏幕上的坐标无非就是:浏览器客户区域里的坐标 + 浏览器窗口坐标 + 客户区偏移,仅此而已。
IE本身就可以通过event和screen对象得到各种屏幕和窗体位置有关的信息。
然而,真正诡异的事还没开始!按照标准的DOM模型定义,只有在触发某个事件的时候,才能从event中获得与该事件相关的参数。
也就是说,只有触发mousemove,等这类mouseXXX鼠标事件时,才有权获取和鼠标有关的参数。然而,在万恶的IE下,任何事件触发后,都能获取event.screenX和event.screenY,甚至在页面最小化时!
当然,你可能会说这还是需要依赖一个事件。然而,这里的事件可以是任意的onxxx这类回调函数,并非局限于UI事件。于是,我们可以人为的制造它!
最简单的例子,给一个new Image设置一个无效的src,它的onerror事件立马就触发了!
于是我们可以在onerror里获取event.screenX,然后继续设置无效的src,于是就可以实时跟踪用户屏幕级别的鼠标指针了。因为onerror的产生不限于任何UI消息,因此页面最小化或非活动状态下,事件仍然能够触发!
至于能不能获取鼠标或键盘哪个键被按下,很不幸,真的不可以。如果捕捉全局按键,哪岂不是可以监听密码输入了。。。
事实上,onerror这类非UI事件的触发,根本就没有任何鼠标或键盘参数传入浏览器窗体,所以也就无法获取各种鼠标键盘信息。至于event.screenX,唯一的解释估计它是event的一个Getter,内部直接调用了GetCursorPos这个Win API,并非事件的触发者提供了这属性。
如果某个页面植入了这样的跟踪代码,然后将坐标位置通过socket.io实时传送回来,岂不是很有趣。。。
关于关于在IE下的一个安全BUG --可用于跟踪用户的系统鼠标位置的用户互动如下:
相关问题:求人做一套系统.关于桌面.IE.鼠标触发事件的...
答:楼主报个底价! 合适就接了! 我用C#做 >>详细
相关问题:放在单元格上,会显示:file:///一个电子表的地址...
答:意思是这个单元格链接到了一个文件,如果你单击会打开超链接(那个电子表),按住才能选中这个单元格。 >>详细
相关问题:windows 7听说可以在网上下载安装系统!请大家提供...
答:如题,请详细指教,谢谢 现在很少人用安装版了,ghost多方便呀,我两个链接都发到你邮箱,你自己决定下哪个吧 ============================================= 【装机新宠 普7风暴】中关村Windows7 SP1万能自选旗舰安装版(32位)V201212 (震撼双PE)... >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【ComboBox】ComboBox 和 DateField 在IE下消失的
- 【ajax】用js来解决ajax读取页面乱码-页面乱码
- 【dom】javascript dom追加内容实现示例-追加内容
- 【has】基于jquery的has()方法以及与find()方法以
- 【extjs】Extjs入门之动态加载树代码-动态加载树
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【angularjs_scope】AngularJS中监视Scope变量以
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
