文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android13 网络 Adb 默认开启

2023-09-08 06:14

关注

Android 13 网络 Adb 默认开启

文章目录

一、前言

通过代码分析发现Android13 上对 网络adb 进行了限制!
Android13原生代码要求:必现连接上某个wifi,才能进行adb ,并且切换wifi或者关闭wifi都是会停止adb。

如果要做成Android11 或者之前一样,设备连接WiFi/有线网络后电脑可以直接进行adb连接,就要对系统代码进行适配修改。

关键:1、mk 设置系统属性:persist.adb.tls_server.enable=12、写死端口号 55553、注释若干判断Wifi情况停止adb的代码

之前以为设置端口号和persist.adb.tls_server.enable 属性就ok了,但是还是有些小bug,还是要完全研究一遍具体流程。

二、默认adb 代码实现

1、修改的目录:

packages\modules\adb\daemon\adb_wifi.cppframework\base\services\core\java\com\android\server\adb\AdbDebuggingManager.java//修改前面两个文件就可以实现adb了,后面的文件试辅助分析的。//虽然 SettingsProvider 也有加载 Settings属性 Settings.Global.ADB_WIFI_ENABLED ,//但是 prop那个属性更优先,所以可以不用考虑这里默认情况framework\base\packages\SettingsProvider\src\com\android\providers\settings\SettingsProvider.java//增加分析定位文件,系统服务启动后会判断 属性persist.adb.tls_server.enable 进行相关操作//如果属性设置不生效,可以在这里添加打印日志查看过程framework\base\services\core\java\com\android\server\adb\AdbService.java

2、具体修改:

(1)在XXX_device.mk 添加属性

persist.adb.tls_server.enable = 1

手动添加,也是会记忆的!

(2)设置固定端口号

+++ b/release/packages/modules/adb/daemon/adb_wifi.cpp@@ -160,7 +160,8 @@ static void enable_wifi_debugging() {     if (sTlsServer != nullptr) {         delete sTlsServer;     }-    sTlsServer = new TlsServer(0);+    // default port 0 means random,change to 5555 ,by liwenzhi+    sTlsServer = new TlsServer(5555);     if (!sTlsServer->Start()) {         LOG(ERROR) << "Failed to start TlsServer";         delete sTlsServer;         

(3)去除判断网络后,设置 ADB_WIFI_ENABLED 为 0 的代码

一个是初始化的时候判断,另外一个是监听网络变化的时候判断,都去掉就行。

+++ b/release/frameworks/base/services/core/java/com/android/server/adb/AdbDebuggingManager.javapublic class AdbDebuggingManager {                case MSG_ADBDWIFI_ENABLE: {                    if (mAdbWifiEnabled) {                        break;                    }                    //not to check network state ,change by  liwenzhi //(1)去除下面一大段判断网络和监听网络的代码                                        //no listener network change for disable adb_wifi,by  liwenzhi                                        SystemProperties.set(WIFI_PERSISTENT_CONFIG_PROPERTY, "1");                case MSG_ADBDWIFI_DISABLE:                    if (!mAdbWifiEnabled) {                        break;                    }                    mAdbWifiEnabled = false;                    setAdbConnectionInfo(null);                    //no need unregisterReceiver, because no listener network,chenge by liwenzhi,//(2)监听已经注释,不需要再注销监听                    //mContext.unregisterReceiver(mBroadcastReceiver);                case MSG_ADBWIFI_ALLOW:                    if (mAdbWifiEnabled) {                        break;                    }                    String bssid = (String) msg.obj;                    boolean alwaysAllow = msg.arg1 == 1;                    if (alwaysAllow) {                        mAdbKeyStore.addTrustedNetwork(bssid);                    }                    // Let's check again to make sure we didn't switch networks while verifying                    // the wifi bssid.                    //no to check network ,change by  liwenzhi //(3)不需要判断网络                                        Settings.Global.putInt(mContentResolver,Settings.Global.ADB_WIFI_ENABLED, 1);                    //no listener network change for disable adb_wifi,by  liwenzhi //(4)不需要要监听网络变化                                        SystemProperties.set(WIFI_PERSISTENT_CONFIG_PROPERTY, "1");

三、日志查看

日志查看主要是:AdbService.java、AdbDebuggingManager.java、adb_wifi.cpp
AdbService 的日志默认是关闭模式的,需要设置成true,并且如果要看里面数据具体值,相关属性的日志需要自己添加打印出来。
AdbDebuggingManager 是有相关异常过程日志的
adb_wifi 该文件的打印,TAG 是adbd, 不管有没有打开adb,整个系统是一直有这个 adbd 的相关打印的,每秒大概有十几行日志!

这里查看打印相关日志多个关键字的信息命令:

logcat | grep -E "lwz|AdbService|changed to|adb wifi|AdbDebuggingManager"

lwz 是我自己加的关键字。

通过日志查看,正常开启的情况大概日志过程是:

01-01 08:00:22.756   496   511 I adbd    : Waiting for persist.adb.tls_server.enable=108-16 15:13:50.123   762   762 D SystemServerTiming: StartAdbService08-16 15:13:51.528   762   762 D AdbService: systemReady //修改 DEBUG = true 才看到的日志08-16 15:13:51.528   762   762 D AdbService: lwz systemReady= persist.adb.tls_server.enable = 1 //自己加的日志打印08-16 15:13:51.528   762   762 D AdbService: lwz systemReady mIsAdbWifiEnabled= true //自己加的日志打印,确认查看服务启动是否打开 adb08-16 15:13:58.993   762   799 D AdbService: setAdbEnabled(true), mIsAdbUsbEnabled=true, mIsAdbWifiEnabled=true, transportType=008-16 15:13:58.994   762   762 D AdbService: lwz onChange shouldEnable = true08-16 15:13:58.995   762   799 D AdbService: setAdbEnabled(true), mIsAdbUsbEnabled=true, mIsAdbWifiEnabled=true, transportType=108-16 15:13:59.015   762   802 D ActivityManagerTiming: OnBootPhase_1000_com.android.server.adb.AdbService$Lifecycle08-16 15:13:59.016   762   802 V ActivityManagerTiming: OnBootPhase_1000_com.android.server.adb.AdbService$Lifecycle took to complete: 1ms08-16 15:13:59.016   762   799 D AdbService: boot completed08-16 15:13:59.033   496   511 I adbd    : persist.adb.tls_server.enable changed to 1 //正常开启adb的日志08-16 15:13:59.056   496   511 I adbd    : adb wifi started on port 555508-16 15:13:59.058   496   511 I adbd    : Waiting for persist.adb.tls_server.enable=0

如果未屏蔽网络判断,添加打印日志查看过程:

08-18 16:51:20.104   762   762 D SystemServerTiming: OnBootPhase_550_com.android.server.adb.AdbService$Lifecycle08-18 16:51:20.104   762   762 D AdbService: systemReady08-18 16:51:20.105   762   762 D AdbService: lwz systemReady mIsAdbWifiEnabled= true //这里说明,prop 属性已经设置了08-18 16:51:26.248   762   798 I AdbDebuggingManager: Not connected to any wireless network. Not enabling adbwifi. //这里提示没网络,会执行关闭adb08-18 16:51:26.586   762   762 D AdbService: lwz onChange shouldEnable = false08-18 16:51:27.411   762   762 D AdbService: lwz onChange shouldEnable = false08-18 16:51:27.971   762   798 D AdbService: setAdbEnabled(true), mIsAdbUsbEnabled=true, mIsAdbWifiEnabled=true, transportType=008-18 16:51:27.972   762   798 D AdbService: setAdbEnabled(false), mIsAdbUsbEnabled=true, mIsAdbWifiEnabled=true, transportType=1 //关闭adb08-18 16:51:27.973   510   517 I adbd    : persist.adb.tls_server.enable changed to 0  //到这里 persist.adb.tls_server.enable 属性又变成了 008-18 16:51:27.973   510   517 I adbd    : adb wifi stopped08-18 16:51:27.981   762   798 D AdbService: Broadcasting enable = false, type = 1

这个也是为啥配置了那个 persist.adb.tls_server.enable =1 属性后,系统启动发现获取属性还是0 ,并且wifi adb未打开。

四、其他

1、adb 相关属性

(1) prop属性:persist.adb.tls_server.enable

系统启动后,AdbService 会判断该属性决定后续是否执行开启adb。

(2)prop属性:service.adb.tls.port

该属性是 adb_wifi.cpp 使能adb的时候设置的. 后续让你知道它的端口号。
所以设置这个属性值是没有意义的。
在 adb_wifi.cpp,初始化 TlsServer 设置固定端口 5555,那么这个属性一直就是 5555.

(3)Settings属性:Settings.Global.ADB_WIFI_ENABLED “adb_wifi_enabled”

同时在 AdbService 是有监听 这个Global 属性的变化,关联上 AdbDebuggingManager ,设置 adb 使能。

查询和设置命令:

//查询属性;setttings get global adb_wifi_enabled//设置属性 0/1:setttings put global adb_wifi_enabled 1

该属性是系统上层设置的一个值,原本主要用来记录adb wifi 的开关状态。
因为Android13 会判断当前wifi是否是信任的,切换wifi后设置这个属性是无效的。

但是如果修改了上面去除网络限制对策后,直接设置Global属性,是会正常开关adb的。

如果未去除网络限制对策,你会发现 adb_wifi_enabled 无法设置成1,
因为 AdbDebuggingManager 在开启的是会还会判断网络情况,如果没有网络会设置为 0 .

2、AdbService.java、AdbDebuggingManager.java、adb_wifi.cpp 的关系

(1) adb_wifi 是底层init/cpp 启动的服务

具体哪里启动的暂不去研究
里面的日志是跑在比较前面的,比SystemServer 更早。
同时也是具体能够使能 网络adb 的关键;
也是为啥设置了 persist.adb.tls_server.enable=1 能够直接使能网络adb的原因。
正常开启和关闭adb 是有相关日志的。

(2)AdbService启动时机

AdbService 是SystemServer 执行 startOtherServices 里面启动的服务。

AdbService extends IAdbManager.Stub //具体暴露接口可以看 IAdbManager

AdbDebuggingManager 是一个管理adbDebug的类,在 AdbService 里面实例化,其实就是分化了一下具体执行的代码。

很多无法进入adb wifi 的情况都是在AdbDebuggingManager 拒绝的,并且重新设置了 Global属性 和 Prop 属性为0

(3)ramework\base\core\java\android\debug\IAdbManager.aidl

package android.debug;import android.debug.FingerprintAndPairDevice;import android.debug.IAdbCallback;interface IAdbManager {        void allowDebugging(boolean alwaysAllow, String publicKey);        void denyDebugging();        void denyWirelessDebugging();        boolean isAdbWifiSupported();}

上面接口估计对开发者没啥用!

适配了去除网络限制上面代码后,就应用而言,使用 Settings.Global.ADB_WIFI_ENABLED 控制和或者当前 网络adb状态最合适的。
虽然使用prop 属性也能生效,但是系统应用Settings判断的是Settings.Global.ADB_WIFI_ENABLED的值是否为1,会出现状态显示不同步的情况。

来源地址:https://blog.csdn.net/wenzhi20102321/article/details/132382549

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯