在 Android 11 (SDK 級別 30) 以上版本中,應用程式可以使用
android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
敬上
目的在於引導使用者新增一或多個已儲存的網路,或
Passpoint 設定。API 會原封不動地修改已儲存的現有設定檔
儲存空間設定
如要儲存網路或 Passpoint 設定,請按照下列步驟操作:
建立
ACTION_WIFI_ADD_NETWORKS
意圖。使用以下程式碼建立一或多項設定:
WifiNetworkSuggestion.Builder
。 請注意,即使您使用WifiNetworkSuggestion
,這個 Intent API 仍會 與 Suggestion API 無關。建立設定的 parcelable 陣列清單,並附加至 意圖
EXTRA_WIFI_NETWORK_LIST
敬上 外加。執行
Activity.startActivityForResult()
、 傳入意圖使用
Activity.onActivityResult()
敬上 回呼。resultCode
可以是下列其中一項:Activity.RESULT_OK
: 表示使用者已接受並儲存提議的網路。Activity.RESULT_CANCELED
: 表示使用者已拒絕提議的網路。
如果
resultCode
是RESULT_OK
,則Intent
資料會包含EXTRA_WIFI_NETWORK_RESULT_LIST
。 額外,包含的結果代碼陣列,指出 已成功儲存設定。可能的結果代碼如下:ADD_WIFI_RESULT_SUCCESS
: 已新增或成功更新設定ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: 嘗試新增設定失敗,例如格式錯誤 此外還會從 0 自動調整資源配置 您完全不必調整資源調度設定ADD_WIFI_RESULT_ALREADY_EXISTS
: 要求的設定已存在,因此您無須採取任何行動。
如果要求成功,平台會觸發與其中一個 儲存 10 個 VM 執行個體
程式碼範例
以下程式碼範例顯示如何儲存網路或 Passpoint 此外還會從 0 自動調整資源配置 您完全不必調整資源調度設定
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
}
}
}