前几天领导吩咐我做个功能,就是用户Android设备连接到PC端后,PC端进行adb push/pull的时候需要先认证操作,认证通过后才能push/pull,这个功能我特么一听,当场就-不会,但是我又想学习下系统层,就去研究下,最开始领导给我的方案是通过FW层的广播来拦截验证命令,然后传到C++层的adb里面,我一听,这么高端,我不配,我这么菜咋个会,我就寻思着先去看看c++层的adb,然后到了adb.cpp(路径:\system\core\adb\adb.cpp),好嘛,我又不会c++,只能边看边猜边百度边问人,我只是个app仔啊,太难了
到了adb.cpp,随便翻了几下,看不懂,突然看到个方法:handle_packet(),哎,这个单词有点熟悉,处理包,这特么不会就是处理adb数据的地方吧
但是玩归玩,闹归闹,我还是不知道这几个case啥意思,我就百度了一手,发现是在c++头文件定义的几种状态,于是来到了adb.h文件下,发现定义了这几种状态
为了搞清楚这几种状态是什么,我在handle_packet()里面打了LOG,然后编译之后通过adb 的logcat来查看分析,发现每次执行adb命令会执行A_OPEN这个状态,这下头绪就出来了,我然后再adb.cpp的handle_packet()方法中,case A_OPEN下,打LOG,然后执行adb push命令,发现传过来的数据p->data为“sync:”,这特么就好说了,我直接判断p->data是否包含“sync:”,这就实现了 adb push/pull的拦截了,那么认证怎么搞呢,我发现adb 有个input的命令(adb shell input text "11111"),这个命令可以传递字符到adb 来,于是我又拦截shell 再增加一个字段判断是否认证成功了,成功了就改变字段
由于对C++代码不精通,这段代码是公司c++崽帮忙写的,具体逻辑就是先判断p->data是否包含shell ,然后再通过查找是否有text的字段,如果有,就取到text后面的字符,在拿到字符和内置的密钥对比,我这里直接写的12345 ,如果对比成功,isAuth就改变,然后拦截到push/pull命令的时候,判断isAuth就好了,就实现了adb 传输文件需要认证的功能了
那么问题来了,adb传输文件都需要认证,那么设备插上USB不是可以直接传输文件嘛,这就要去修改USB连接模式了,就在我上一篇文章中,各位看官老爷可以去一起讨论下
由于我刚接触系统层源码,可能还处于比较菜的地步,如果有错误的地方,麻烦大佬指点下,感谢感谢........