Android 11以上App主动连接WIFI的完整方案

早期Android版本App内连接指定的WIFI还是比较简单的,但是随着Android版本的提升,限制也越来越多。以下是一套完整的Android 11以上的WIFI应用内主动连接方案。

第一步:添加到建议连接:

Kotlin 复制代码
val wifiManager = getSystemService(WIFI_SERVICE) as WifiManager

//一定要加,不然切换指定WIFI无效
wifiManager.removeNetworkSuggestions(wifiManager.networkSuggestions)
val suggestion = WifiNetworkSuggestion.Builder()
                    .setSsid(ssid)
                    .setWpa2Passphrase((pwd))
                    .setIsAppInteractionRequired(false)
                    .build()
val suggestionsList = ArrayList<WifiNetworkSuggestion>()
suggestionsList.add(suggestion)
val status: Int = wifiManager.addNetworkSuggestions(suggestionsList)
if (status == WifiManager.STATUS_NETWORK_SUGGESTIONS_SUCCESS) {

}

但是这里有一个问题:这个是建议,不一定能连上。这就很让人难受!

第二步:监听网络状态:

Kotlin 复制代码
private val networkCallback = object : ConnectivityManager.NetworkCallback() {
        override fun onAvailable(network: Network) {
            super.onAvailable(network)
            Log.d(TAG, "用户已连接到网络")
            val capabilities = mConnectivityManager!!.getNetworkCapabilities(network)
            Log.d(TAG, "$capabilities")
            if (capabilities?.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) == true) {
                // 获取当前连接的WiFi信息
                val wifiInfo = wifiManager!!.connectionInfo
                Log.d(TAG, "wifi info = $wifiInfo")
                if (wifiInfo.ssid == String.format("\"%s\"", TEST_WIFI_SSID))
                ) {
                    Log.d(TAG, "用户已连接到建议的网络")
                    Prefs.isWifiConnected = true
                    Prefs.currentWifiSsid = wifiInfo.ssid
                }
            }
        }

        override fun onUnavailable() {
            super.onUnavailable()
            Log.d(TAG, "用户未连接到建议的网络")
            clearWifiState()
        }
    }

mConnectivityManager = getSystemService(CONNECTIVITY_SERVICE) as ConnectivityManager
        // 注册回调
val request = NetworkRequest.Builder()
            .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET)
            .addTransportType(NetworkCapabilities.TRANSPORT_WIFI)
            .build()
mConnectivityManager?.registerNetworkCallback(request, networkCallback)

第三步:如果10s内未主动连接上,跳转到WIFI设置页(注意:到这个页面也会主动连接,目测基本100%成功率)

Kotlin 复制代码
lifecycleScope.launch {
            delay(10_000)
            if (!Prefs.isWifiConnected) {
                val intent = Intent(Settings.ACTION_WIFI_SETTINGS)
                startActivity(intent)
            }
        }
相关推荐
安卓开发者2 小时前
Android RxJava 组合操作符实战:优雅处理多数据源
android·rxjava
阿华的代码王国2 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼2 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jerry说前后端2 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
alexhilton3 小时前
深入浅出着色器:极坐标系与炫酷环形进度条
android·kotlin·android jetpack
一条上岸小咸鱼9 小时前
Kotlin 基本数据类型(一):Numbers
android·前端·kotlin
Huntto9 小时前
最小二乘法计算触摸事件速度
android·最小二乘法·触摸事件·速度估计
一笑的小酒馆9 小时前
Android中使用Compose实现各种样式Dialog
android
红橙Darren9 小时前
手写操作系统 - 编译链接与运行
android·ios·客户端
鹏多多.13 小时前
flutter-使用device_info_plus获取手机设备信息完整指南
android·前端·flutter·ios·数据分析·前端框架