在 Android 11 (SDK 級別 30) 以上版本中,應用程式可以使用 android.provider.Settings.ACTION_WIFI_ADD_NETWORKS 意圖,引導使用者新增一或多個已儲存的網路或 Passpoint 設定。這個 API 也可直接用來修改現有的已儲存設定。
如要儲存網路或 Passpoint 設定,請按照下列步驟操作:
建立
ACTION_WIFI_ADD_NETWORKS意圖。使用
WifiNetworkSuggestion.Builder建立一或多個設定。請注意,即使您使用WifiNetworkSuggestion,這個 Intent API 也與建議 API 無關。建立設定的可封送陣列清單,並使用
EXTRA_WIFI_NETWORK_LIST額外項目將其附加至意圖。執行
Activity.startActivityForResult(),並傳入意圖。使用
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
        }
    }
}