聯網

Android 10 包括以下網絡模塊:

  • 網絡組件模塊提供通用 IP 服務、網絡連接監控和強制登錄門戶檢測。
  • Network Stack Permission Config 模塊定義了一個允許模塊執行網絡相關任務的權限。

網絡組件模塊

網絡組件模塊確保 Android 能夠適應不斷發展的網絡標準,並允許與新實現的互操作性。例如,強制門戶檢測和登錄代碼的更新使 Android 能夠隨著強制門戶模型的變化與時俱進,高級策略防火牆 (APF) 的更新允許 Android 隨著新型數據包變得普遍而節省 Wi-Fi 的電量。

Android 10 中的變化

網絡組件模塊包含以下組件。

  • 知識產權服務。 IpClient(以前稱為 IpManager)組件處理 IP 層配置和維護。在 Android 9 中,它被藍牙等組件跨進程使用,被 Wi-Fi 等組件在進程內使用。 DhcpClient 組件從 DHCP 服務器獲取 IP 地址,以便將它們分配給接口。
  • 網絡監視器。 NetworkMonitor 組件在連接到新網絡或網絡故障、檢測強制門戶以及驗證網絡時測試 Internet 可達性。
  • 強制門戶登錄應用程序。 Captive Portal 登錄應用程序是一個預裝的應用程序,負責管理 Captive Portal 上的登錄。這自 Android 5.0 以來一直是一個單獨的應用程序,但它與 NetworkMonitor 交互以將一些用戶選擇轉發給系統。

關於使用網絡組件模塊裝置中,上述服務重構為一個不同的過程,並且使用被訪問穩定AIDL接口。重構路徑如下表所示。

IP 服務重構路徑

Android 9 及更低版本frameworks/base/services/net/java/android/net/
  • apf
  • dhcp
  • ip
  • netlink
  • util (部分)
Android 10 及更高版本packages/modules/NetworkStack

強制門戶登錄重構路徑

Android 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,並接受一致性測試。

網絡棧權限配置模塊

網絡堆棧權限配置模塊不包含任何代碼,而是定義了供網絡堆棧和強制門戶登錄模塊使用的權限。系統允許被授予此權限的模塊在設備上執行相關的網絡配置任務。