在 Android 11(SDK 级别 30)及更高版本中,应用可以使用
android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
目的是引导用户添加一个或多个新的已保存网络,或者
Passpoint 配置。该 API 也可按原样修改已保存的
配置。
如需保存网络或 Passpoint 配置,请执行以下操作:
创建一个
ACTION_WIFI_ADD_NETWORKS
intent。使用以下内容创建一项或多项配置:
WifiNetworkSuggestion.Builder
。 请注意,即使您使用WifiNetworkSuggestion
,此 Intent API 也会 与 Suggestion API 无关。创建配置的 Parcelable 数组列表,并将其附加到 传递
EXTRA_WIFI_NETWORK_LIST
extra。执行
Activity.startActivityForResult()
、 传递 intent。使用
Activity.onActivityResult()
回调。resultCode
可以是以下项之一:Activity.RESULT_OK
: 表示用户已接受建议的网络并保存。Activity.RESULT_CANCELED
: 表示用户拒绝了建议的网络。
如果
resultCode
为RESULT_OK
,则数据Intent
包含EXTRA_WIFI_NETWORK_RESULT_LIST
extra,其中包含一组结果代码,用于指示 已成功保存配置。可能的结果代码包括: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
}
}
}