当前位置:首页 » 《随便一记》 » 正文

Android设备在PC端上通过adb push/pull时需要验证的方案解决(push/pull之前需要先通过某些方式验证,之后才能push/pull)_LINENG185的博客

17 人参与  2022年06月05日 10:35  分类 : 《随便一记》  评论

点击全文阅读


        前几天领导吩咐我做个功能,就是用户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连接模式了,就在我上一篇文章中,各位看官老爷可以去一起讨论下

由于我刚接触系统层源码,可能还处于比较菜的地步,如果有错误的地方,麻烦大佬指点下,感谢感谢........

 

 

 


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/41417.html

命令  认证  拦截  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1