Android 13 网络 Adb 默认开启
文章目录
- 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