Android 10 包括以下網絡模塊:
- 網絡組件模塊提供通用 IP 服務、網絡連接監控和強制登錄門戶檢測。
- Network Stack Permission Config 模塊定義了一個允許模塊執行網絡相關任務的權限。
網絡組件模塊
Networking Components 模塊確保 Android 能夠適應不斷發展的網絡標準,並允許與新實現的互操作性。例如,強制門戶檢測和登錄代碼的更新使 Android 能夠及時了解不斷變化的強制門戶模型,高級策略防火牆 (APF) 的更新允許 Android 在新類型的數據包變得普遍時節省 Wi-Fi 電源。
Android 10 的變化
網絡組件模塊包含以下組件。
- 知識產權服務。 IpClient(以前稱為 IpManager)組件處理 IP 層配置和維護。在 Android 9 中,它被藍牙等組件跨進程使用,而 Wi-Fi 等組件在進程內使用。 DhcpClient 組件從 DHCP 服務器獲取 IP 地址,以便將它們分配給接口。
- 網絡監視器。 NetworkMonitor 組件在連接到新網絡或網絡故障、檢測強制門戶以及驗證網絡時測試 Internet 可訪問性。
- 強制門戶登錄應用程序。強制門戶登錄應用程序是一個預安裝的應用程序,負責管理強制門戶的登錄。自 Android 5.0 以來,這一直是一個單獨的應用程序,但它與 NetworkMonitor 交互以將一些用戶選擇轉發給系統。
在使用網絡組件模塊的設備上,上述服務被重構為不同的進程,並使用穩定的 AIDL 接口進行訪問。重構路徑如下表所示。
IP 服務重構路徑
安卓 9 及更低版本 | 在frameworks/base/services/net/java/android/net/ 中:
|
---|---|
Android 10 及更高版本 | packages/modules/NetworkStack |
強制門戶登錄重構路徑
安卓 9 及更低版本 | 在frameworks/base/ 中:
|
---|---|
Android 10 及更高版本 | packages/modules/CaptivePortalLogin (以及其他一些共享位置) |
格式和依賴
網絡組件模塊以三個 APK 的形式提供:一個用於 IP 服務,一個用於強制門戶登錄,一個用於網絡堆棧權限配置。
網絡組件模塊依賴於以下內容:
- 系統服務器中的特權
@hide
方法(例如,在IConnectivityManager.aidl
中)。這些 API 已使用@SystemApi
進行註釋並受到適當保護,以便模塊可以訪問它們,但其他特權應用程序不能訪問它們(例如,使用新的簽名權限)。 - 綁定 IPC 到
netd
中定義的INetd.aidl
。此接口已轉換為穩定的 AIDL,並接受一致性測試。
網絡堆棧權限配置模塊
Network Stack Permission Config 模塊不包含任何代碼,而是定義了一個供 Network Stack 和 Captive Portal Login 模塊使用的權限。系統允許被授予此權限的模塊在設備上執行相關的網絡配置任務。