监控网络连接状态和网络连接计量

ConnectivityManager 提供了一个 API,可让您根据各种条件(包括设备功能和数据传输选项)请求设备连接到网络。

回调实现会向您的应用提供有关设备连接状态以及当前连接的网络功能的信息。借助该 API,您可以确定设备当前连接到的网络是否符合应用要求。

配置网络请求

如需指定网络的传输类型(例如 Wi-Fi 或移动网络连接)以及当前已连接网络的功能(例如互联网连接),您必须配置网络请求。

声明一个 NetworkRequest,用于说明应用的网络连接需求。以下代码会创建对连接到互联网的网络的请求,并使用 Wi-Fi 或移动网络连接作为传输类型。

Kotlin

val networkRequest = NetworkRequest.Builder()
        .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET)
        .addTransportType(NetworkCapabilities.TRANSPORT_WIFI)
        .addTransportType(NetworkCapabilities.TRANSPORT_CELLULAR)
        .build()

Java

NetworkRequest networkRequest = new NetworkRequest.Builder()
        .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET)
        .addTransportType(NetworkCapabilities.TRANSPORT_WIFI)
        .addTransportType(NetworkCapabilities.TRANSPORT_CELLULAR)
        .build();

请注意,某些连接的费用可能比其他连接高得多(例如,移动网络连接通常费用较高)。使用 NetworkCapabilities#NET_CAPABILITY_NOT_METERED 确定连接是否耗费资源。在使用按流量计费的网络连接时,请尝试减少应用的数据流量消耗,或者暂时不用,等设备连接到不按流量计费的网络后再用。

配置网络回调

ConnectivityManager 注册 NetworkRequest 时,您必须实现 NetworkCallback,以接收有关连接状态和网络功能变化的通知。

NetworkCallback 中最常实现的函数包括:

Kotlin

private val networkCallback = object : ConnectivityManager.NetworkCallback() {
    // network is available for use
    override fun onAvailable(network: Network) {
        super.onAvailable(network)
    }

    // Network capabilities have changed for the network
    override fun onCapabilitiesChanged(
            network: Network,
            networkCapabilities: NetworkCapabilities
    ) {
        super.onCapabilitiesChanged(network, networkCapabilities)
        val unmetered = networkCapabilities.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED)
    }

    // lost network connection
    override fun onLost(network: Network) {
        super.onLost(network)
    }
}

Java

private ConnectivityManager.NetworkCallback networkCallback = new ConnectivityManager.NetworkCallback() {
    @Override
    public void onAvailable(@NonNull Network network) {
        super.onAvailable(network);
    }

    @Override
    public void onLost(@NonNull Network network) {
        super.onLost(network);
    }

    @Override
    public void onCapabilitiesChanged(@NonNull Network network, @NonNull NetworkCapabilities networkCapabilities) {
        super.onCapabilitiesChanged(network, networkCapabilities);
        final boolean unmetered = networkCapabilities.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED);
    }
};

注册接收网络更新

声明 NetworkRequestNetworkCallback 后,使用 requestNetwork()registerNetworkCallback() 函数搜索满足 NetworkRequest 条件的设备可连接的网络。然后,系统会将状态报告给 NetworkCallback

Kotlin

val connectivityManager = getSystemService(ConnectivityManager::class.java) as ConnectivityManager
connectivityManager.requestNetwork(networkRequest, networkCallback)

Java

ConnectivityManager connectivityManager =
        (ConnectivityManager) getSystemService(ConnectivityManager.class);
connectivityManager.requestNetwork(networkRequest, networkCallback);