位置: 编程技术 - 正文

Android 键盘监控的实现原理及过程(怎么监控键盘输入)

编辑:rootadmin

推荐整理分享Android 键盘监控的实现原理及过程(怎么监控键盘输入),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android键盘监听,手机键盘监控专家,手机键盘监控软件,android键盘监听,android 监听键盘输入,android键盘监听,android键盘监听,手机键盘监控软件,内容如对您有帮助,希望把文章链接给更多的朋友!

键盘监控

键盘监控,顾名思义是在应用软件在运行时,用户在设备上的一举一动都将被详细记录下来,更多的实在使用者毫无觉察的情况下将屏幕内容以图片的形式、按键内容以文本文档的形式保存在指定的文件夹或发送到指定的邮箱。键盘监控,包括物理按键与软键盘的监控,通常监控的事件有:点击,长按,滑动等,这些时间在Android上表现出来的都是一系列的KeyEvent。

为了实现键盘的监控,从新开发一个输入法是不现实的,一般的操作就是在系统的输入法机制中添加接口回调。我们知道,再应用程序中拿到按键的回调一般是监听onKeyDown的接口,如下所示:

开发者就可以根据回调方法中的参数, keyCode与KeyEvent来判断具体事件。但是,由于事件的回调机制在其的沙箱中运行,在其他应用中是无法拿到当前应用事件回调的。

那么我们就从上到下,具体的看看事件的传递机制。如下图所示,用户点击后,软键盘或物理按键的输入驱动就会产生一个中断,且向/dev/input/event*中写入一个相应的信号量。Android操作系统则会循环的读取其中的事件,再分发给WindowManagerServer。由WindowManagerServer根据事件的来源分发到各个不同的ViewGroup与View中,从而产生不同的OnClick、OnKeyDown和OnTouch等事件。

这个时候很自然的想到,黑客们希望做键盘监控,一定会向Linux底层增加自定义的事件。这里我们使用的是Linux中的getevent获得/dev/input/eventX设备汇报的事件,这个命令还会输出所有event设备的基本信息。包括触屏、按键、耳机插入等等。其基本用法如下:

键入getevent后,我们能够看到设备中的一些列输入硬件驱动信息,同样下面会出现很多输入指令信号,通常情况下,这些信号量都在刷屏,如下图所示:

这些信号量的表示我们无法直接看懂,输入getevent –l加入Label我们能够看到一些添加的标签,如下所示:

Android 键盘监控的实现原理及过程(怎么监控键盘输入)

其实这些Lable已经在其input.h头文件中定义好,其中type的定义如下:

一般来说,常用的是EV_KEY、EV_REL、EV_ABS、EV_SYN,分别对应键盘按键、相对坐标、绝对坐标、同步事件。EV_SYN则表示一组完整事件已经完成,需要处理,EV_SYN的code定义事件分发的类型。

在触摸事件上的几个常见的Label说明如下表所示:

标签名说明ABS_X对应触摸屏的X坐标ABS_Y对应触摸屏的Y坐标ABS_PRESSURE压力&#;,一般触摸屏也只是区分是否有按下去,按下去的话&#;会大于多少,没有按的话&#;小于多少。ABS_TOOL_WIDTH触摸工具的宽度ABS_MT_POSITION_X接触面的形心的X坐标&#;ABS_MT_POSITION_Y接触面的形心的Y坐标&#;ABS_MT_TOUCH_MAJOR触摸手指大小ABS_MT_WIDTH_MAJOR触摸面积大小

了解了这些Label的含义我们再看看信号量就简单多了,如我们列举几个常见的事件与信号,如下表所示:

操作输出信号按下电源键/dev/input/event0: EV_KEY KEY_POWER DOWN/dev/input/event0: EV_SYN SYN_REPORT /dev/input/event0: EV_KEY KEY_POWER UP/dev/input/event0: EV_SYN SYN_REPORT 音量键下/dev/input/event8: EV_KEY KEY_VOLUMEDOWN DOWN/dev/input/event8: EV_SYN SYN_REPORT /dev/input/event8: EV_KEY KEY_VOLUMEDOWN UP/dev/input/event8: EV_SYN SYN_REPORT 音量键上/dev/input/event8: EV_KEY KEY_VOLUMEUP DOWN/dev/input/event8: EV_SYN SYN_REPORT /dev/input/event8: EV_KEY KEY_VOLUMEUP UP/dev/input/event8: EV_SYN SYN_REPORT 按下物理按键“1”/dev/input/event0: EV_KEY KEY_1 DOWN/dev/input/event0: EV_KEY KEY_1 UP按下物理按键“q”/dev/input/event0: EV_KEY KEY_Q DOWN/dev/input/event0: EV_KEY KEY_Q UP按下软键盘上的“q”字母/dev/input/event0: EV_ABS ABS_X b/dev/input/event0: EV_ABS ABS_Y d5/dev/input/event0: EV_KEY BTN_TOUCH DOWN/dev/input/event0: EV_SYN SYN_REPORT /dev/input/event0: EV_KEY BTN_TOUCH UP/dev/input/event0: EV_SYN SYN_REPORT 按下软件键盘上的的“1”按键/dev/input/event0: EV_ABS ABS_X /dev/input/event0: EV_ABS ABS_Y d7/dev/input/event0: EV_KEY BTN_TOUCH DOWN/dev/input/event0: EV_SYN SYN_REPORT /dev/input/event0: EV_KEY BTN_TOUCH UP/dev/input/event0: EV_SYN SYN_REPORT

从上表中,我们发现要是按下的是物理按键,其输入出来的信息我们很容易读懂,如果按下的是软键盘中的按键,给出的信号信息就是一些位置坐标信息。我们无法直接读懂,当然,我们可以根据这些位置坐标信息,再拿到Android设备的屏幕尺寸,计算比例也能够直接获得按键的具体内容。

当然,输出条件不会是想我们表&#;中的这么规范,中间会夹杂则各式各样的信息,有些可能是你不关心的。这里我们把一些无关的信号量过滤去掉了。实际查看上对应信息条件比较多,大家可以将Android设备连接如自己的电脑进行调试,这里我们就不做一一的解释了。

预防键盘监控

所以,为了安全起见,很多对于输入安全要求比较高的应用软件,除了自定义输入法进行安全输入以外,还需要将键盘上的各个字母数字位置随机打乱,防止黑客们在截获了位置信息后进行按键计算。这个也就是我们常在一些软件中看到打乱的键盘原因,打乱键盘效果如下图所示:

getevent是一个系统级命令,需要在Root情况下才可以使用。这里我们对getevent作为阐述,的主要目的就是告诉大家,在Root后的Android设备中,我们可以使用对Linux底层信号做读取的方式,对设备进行键盘监控。当然,更可以使用sendevent命令,模拟发送事件,这里我们不做阐述了。

Android面试宝典(一位优秀应届生面试经验,很多Android高阶问题) Android面试宝典写一个专属自己的面试宝典:小巫写这篇面试宝典,主要是为了积累经验和记录自己的求职之路。小巫并不是一种教导别人怎么去面试的

Android之Adapter用法总结 1.概念Adapter是连接后端数据和前端显示的适配器接口,是数据和UI(View)之间一个重要的纽带。在常见的View(ListView,GridView)等地方都需要用到Adapter。如

onSaveInstanceState和onRestoreInstanceState触发的时机 当某个activity变得容易被系统销毁时,该activity的onSaveInstanceState就会被执行,除非该activity是被用户主动销毁的,例如当用户按BACK键的时候。注意上面的

标签: 怎么监控键盘输入

本文链接地址:https://www.jiuchutong.com/biancheng/382291.html 转载请保留说明!

上一篇:ShareSdk实现第三方分享功能

下一篇:Android面试宝典(一位优秀应届生面试经验,很多Android高阶问题)(android面试2021)

  • 收到个税返还手续费怎么算增值税附加
  • 投资性房地产采用成本模式计量
  • 月末转出未交增值税时应借记的科目是
  • 银行开具的票据有哪些
  • 无法支付的应付账款需要交增值税吗
  • 医疗费用收费票据
  • 电子发票和纸质发票只能二选一吗
  • 公司注销单位社保欠费怎么处理
  • 个人所得税怎么扣
  • 房地产企业开发间接费用包括哪些
  • 公司买入股票要交所得税吗?
  • 土地增值税扣除系数
  • 税率修改后对价格的影响
  • 库存商品低价销售违法吗
  • 施工企业增值税纳税地点
  • 一般纳税人开技术服务费
  • 货物运输企业纳税多少
  • 建筑企业的职工由于不服管理违反规章制度
  • 电子税务局怎么变更财务负责人
  • 收到场地租赁费入什么科目
  • 工会经费,职工福利费,教育经费的扣除标准
  • 应付职工薪酬账户结构
  • 辞职的补偿金怎么做账
  • cpu资源占用高怎么办
  • php缓存机制有哪些
  • windows10更新会丢失数据吗
  • Linux系统中怎么开机自动运行拍摄文件
  • 公司法人向公司借款未还,公司可以倒闭吗
  • 工程项目会计怎么样
  • 英国布莱顿霍夫怎么样
  • 座头鲸救人
  • 个人开发app最简单方法
  • 2022年数学建模获奖结果
  • 计算机还热门吗
  • 准确率精确率
  • 间接费用计算
  • 房子是固定资产的好处
  • 互联网+文本格式
  • centos离线安装mondo
  • 企业投资一个小时多少钱
  • 公司月报和季报
  • 以房租入股公司怎么交税
  • ms-sql-s
  • 企业合并的账务处理
  • acca考试安排及时间
  • 员工餐费报销分录怎么弄
  • 合并报表抵消分录的基本原理
  • 员工意外险税前扣除比例
  • 固定资产内部转移流程
  • 研发过程4个主要阶段
  • 加计扣除是指什么意思
  • 因质量问题质保金未能收回怎么处理
  • 定额发票收入怎么样确定
  • 装修工程人工费占总价比例
  • 预付账款属于资产类科目
  • 建筑行业总产值占我国GDP的比重
  • 新公司季初资产总额填什么
  • 跨年材料票可以入账吗
  • 收到现金支票没有盖章
  • 红字冲销发票的作用
  • 依法建账的法是指
  • 如何在windows server 2016如何加域
  • centos下netconfig 的安装方法
  • win8 网络连接
  • win7网络连接不显示
  • win10系统自带输入法怎么关闭
  • 宏基win8改win7
  • linux文件系统的根目录的i节点号为
  • [置顶]bilinovel
  • nodejs调用go
  • bootstrap滚动监听效果
  • vue仿知乎
  • convert fs
  • Python 数据清洗
  • unity改vs版本
  • jQuery 3.0 的 setter和getter 模式详解
  • 安卓开发速成
  • python traits
  • 个人所得税超过12万能退税吗
  • 贵州税务开票系统登录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设