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)
            }
        }
相关推荐
小书房3 小时前
Kotlin的by
android·开发语言·kotlin·委托·by
jinanwuhuaguo3 小时前
(第二十八篇)OpenClaw成本与感知的奇点——从“Token封建制”到“全民养虾”的本体论地基
android·人工智能·kotlin·拓扑学·openclaw
xxjj998a4 小时前
Laravel4.x核心特性全解析
android·mysql·laravel
JoshRen5 小时前
2026教程:在Android Termux中集成Gemini 3镜像站实现移动端文档自动处理与摘要生成(附国内免费方案)
android
诸神黄昏EX5 小时前
Android Google KEY
android
一起搞IT吧5 小时前
Android性能系列专题理论之十一:block IO问题分析思路
android·嵌入式硬件·智能手机·性能优化
小妖6666 小时前
怎么用 tauri 创建编译 android 应用程序
android·tauri
鸟儿不吃草7 小时前
安卓实现左右布局聊天界面
android·开发语言·python
xxjj998a9 小时前
Laravel 1.x:PHP框架的原始魅力
android·php·laravel
formula100009 小时前
在iOS/安卓上远程连接任何 Agent!Claude、Codex、Copilot、Gemini、OpenCode 等
android·copilot