记一次Android机顶盒破解工程

        因项目的需要,需要在主设备中集成一个卫星接收机(解调解码)用来接收下行信号,但是专业级的接收机设备都太贵,所以用了一个便宜的民用DVB-S2机顶盒代替,DVB-S2机顶盒的其中一部分是解调解码功能,这个设备是一个Android系统,然后内置的一个解调解码程序,整个机顶盒设备是需要红外遥控控制的。 

        刚开始的思路是想把机顶盒中的解调解码程序反编译,然后寻找相关设置参数的代码片段,但是反编译之后我发现这个代码量巨大,而且不知道如何调试,所以放弃了这个方案。后来又想了一个方案,具体步骤如下 

1、 调试机顶盒 

        保证机顶盒和电脑在同一个局域网中,采用adb connect 192.168.1.123连接机顶盒ip。 

2、获取系统输入事件 

        红外遥控按钮在按下的一瞬间,Android系统可以通过geteven指令捕获系统输入事件,如下图,下图是红外按钮的方向键“下”键的指令 


        在得到每个按键的具体信息之后可以通过sendevent指令发送指定的按键信息,如下图

        设备在收到指令之后会出现相关的反应,我上面发送的指令是让系统弹出设置菜单

3、写程序。 

        代码中指令

        通过getevent指令得到具体的输入事件信息之后,我把红外遥控器上有关设置解调解码相关步骤所用的按钮一一获取了事件信息,如下图

        这样就可以通过Android程序模拟红外按键了,但是这样做并不能解决全部问题,试想一下,采用程序模拟按键的话,在盲按的情况下很容易按着按着导致界面跑飞,因为有些按键只能在特定的界面才管用,后来我又想了一个办法,采用AccessibilityService进行界面的判断,这样一来可以解决因为按键乱按导致界面跑飞的情况,二来可以提高设置参数的精确性,因为有些界面比较复杂,用模拟按键操作的话,可能需要按好几次,比如说一个列表,如下图。

        我需要设置“Transponder List”参数的话,需要模拟方向按键的“下”键四次,但是通过AccessibilityService之后,我只需要知道“Transponder List”按钮对应的ID然后采用Android中的AccessibilityNodeInfo的performAction函数就可以瞬间按下“Transponder List”按钮,提高了速度和成功率。“Transponder List”的ID可以通过eclipse中的“dump View Hierarchy for UI automator”工具可以得到 

    我把上面的程序做成一个后台服务,没有显示界面,如下图。

        而且相关的设置参数需要通过主设备的Socket传递过来,AccessibilityService程序是一个特殊的程序,需要在Android系统界面中设置该程序的AccessibilityService服务开启,否则AccessibilityService不会执行

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,256评论 25 709
  • 我们不能独自一人生存下去,我们都是相互依靠,相互支撑着走完这一生。所以作为大学生的我,也要慢慢地从父母的怀抱中走出...
    白芙默阅读 2,972评论 0 1
  • 作为新时代四大发明之一的“支付宝”、“微信”们,我们一边享受着科技带来的便利感和轻松感,我们再也不用怕忘带钱包了。...
    果喵阅读 1,105评论 0 0
  • 很想把自己的故事通过文字体现出来,关于老猫,关于那时候细腻的情感。 不知道该如何开始起笔,每次脑海里一遍一遍地重复...
    笑风丽影阅读 1,495评论 0 0
  • 最近因接连不断的大额业务搞得本月成了一年中最暗无天日、心力交瘁的日子!仿佛每一天都是在煎熬和打仗中渡过,就像手里拿...
    人活一生通透简单阅读 1,430评论 1 4