聯網

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/中:
  • apf
  • dhcp
  • ip
  • netlink
  • util (部分)
Android 10 及更高版本packages/modules/NetworkStack

強制門戶登錄重構路徑

安卓 9 及更低版本frameworks/base/中:
  • core/java/android/net/captiveportal/
  • services/core/java/com/android/server/connectivity/NetworkMonitor.java
  • packages/CaptivePortalLogin/* (其中 * = 通配符)
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 模塊使用的權限。系統允許被授予此權限的模塊在設備上執行相關的網絡配置任務。