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)
            }
        }
相关推荐
游戏开发爱好者821 小时前
iOS 26 iPhone 使用记录分析 多工具组合构建全方位设备行为洞察体系
android·ios·小程序·uni-app·cocoa·iphone·webview
zhangphil1 天前
HARDWARE 属性的Bitmap与普通Bitmap,GPU与RenderThread渲染与处理方式异同比较,Android
android
消失的旧时光-19431 天前
Flutter 异步编程:Future 与 Stream 深度解析
android·前端·flutter
alexhilton1 天前
Compose CameraX现已稳定:给Composer的端到端指南
android·kotlin·android jetpack
阿里云云原生1 天前
移动端性能监控探索:可观测 Android 采集探针架构与实现
android
雨白1 天前
玩转 Flow 操作符(一):数据转换与过滤
android·kotlin
二流小码农1 天前
鸿蒙开发:web页面如何适配深色模式
android·ios·harmonyos
消失的旧时光-19431 天前
TCP 流通信中的 EOFException 与 JSON 半包问题解析
android·json·tcp·数据
JiaoJunfeng1 天前
android 8以上桌面图标适配方案(圆形)
android·图标适配
参宿四南河三1 天前
Android Compose快速入门手册(真的只是入门)
android·app