在 Android 11(SDK 级别 30)及更高版本中,应用可以使用 android.provider.Settings.ACTION_WIFI_ADD_NETWORKS intent 来引导用户添加一个或多个新的已保存网络或 Passpoint 配置。该 API 也可按原样用于修改现有的已保存配置。
如需保存网络或 Passpoint 配置,请执行以下操作:
- 创建 - ACTION_WIFI_ADD_NETWORKS意图。
- 使用 - WifiNetworkSuggestion.Builder创建一个或多个配置。请注意,即使您使用- WifiNetworkSuggestion,此 Intent API 也与建议 API 无关。
- 创建配置的可封装数组列表,并使用 - EXTRA_WIFI_NETWORK_LISTextra 将其附加到 intent。
- 执行 - Activity.startActivityForResult(),并传入 intent。
- 使用 - Activity.onActivityResult()回调监听结果。- resultCode可以是下列选项之一:- Activity.RESULT_OK:表示用户接受了建议的网络并保存了这些网络。
- Activity.RESULT_CANCELED:表示用户拒绝了建议的网络。
 - 如果 - resultCode为- RESULT_OK,则数据- Intent包含- EXTRA_WIFI_NETWORK_RESULT_LISTextra,其中包含一个结果代码数组,用于指示各个配置是否已成功保存。可能的结果代码包括:- ADD_WIFI_RESULT_SUCCESS:已添加或成功更新配置。
- ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED:尝试添加配置时失败,例如由于配置格式不正确。
- ADD_WIFI_RESULT_ALREADY_EXISTS:所请求的配置已存在,因此无需执行任何操作。
 
- 如果请求成功,平台会触发与新保存的网络之一的连接。 
代码示例
以下代码示例展示了如何保存网络或 Passpoint 配置。
class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        ...
    }
    fun startOperation() {
        val suggestions = ArrayList<WifiNetworkSuggestion>()
        // WPA2 configuration
        suggestions.add(
                WifiNetworkSuggestion.Builder()
                        .setSsid("test111111")
                        .setWpa2Passphrase("test123456")
                        .build()
        )
        // Open configuration
        suggestions.add(
                WifiNetworkSuggestion.Builder()
                        .setSsid("test222222")
                        .build()
        )
        // Passpoint configuration
        val config = PasspointConfiguration()
        config.credential = Credential().apply {
            realm = "realm.example.com"
            simCredential = Credential.SimCredential().apply {
                eapType = 18
                imsi = "123456*"
            }
        }
        config.homeSp = HomeSp().apply {
            fqdn = "test1.example.com"
            friendlyName = "Some Friendly Name"
        }
        suggestions.add(
                WifiNetworkSuggestion.Builder()
                        .setPasspointConfig(config)
                        .build())
        // Create intent
        val bundle = Bundle()
        bundle.putParcelableArrayList(EXTRA_WIFI_NETWORK_LIST, suggestions)
        val intent = Intent(ACTION_WIFI_ADD_NETWORKS)
        intent.putExtras(bundle)
        // Launch intent
        startActivityForResult(intent, 0)
    }
    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        if(resultCode == RESULT_OK) {
            // user agreed to save configurations: still need to check individual results
            if (data != null && data.hasExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
                for (code in data.getIntegerArrayListExtra(EXTRA_WIFI_NETWORK_RESULT_LIST)) {
                    when (code) {
                        ADD_WIFI_RESULT_SUCCESS ->
                            ... // Configuration saved or modified
                        ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED ->
                            ... // Something went wrong - invalid configuration
                        ADD_WIFI_RESULT_ALREADY_EXISTS ->
                            ... // Configuration existed (as-is) on device, nothing changed
                        else ->
                            ... // Other errors
                    }
                }
            }
        } else {
            // User refused to save configurations
        }
    }
}
