Su Android 11 (livello SDK 30) e versioni successive, le app possono utilizzare l'intent
android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
per guidare l'utente nell'aggiunta di una o più nuove reti salvate o
configurazioni Passpoint. L'API funziona anche così com'è per modificare le configurazioni salvate esistenti.
Per salvare una rete o una configurazione Passpoint:
Crea un'intenzione
ACTION_WIFI_ADD_NETWORKS
.Crea una o più configurazioni utilizzando
WifiNetworkSuggestion.Builder
. Tieni presente che, anche se utilizzi un'WifiNetworkSuggestion
, questa API Intent non è correlata all'API Suggestion.Crea un elenco di array parcelable delle configurazioni e allegalo all'intent con l'extra
EXTRA_WIFI_NETWORK_LIST
.Esegui
Activity.startActivityForResult()
, passando l'intent.Ascolta il risultato utilizzando il callback di
Activity.onActivityResult()
.resultCode
può essere uno dei seguenti:Activity.RESULT_OK
: indica che l'utente ha accettato le emittenti proposte e le ha salvate.Activity.RESULT_CANCELED
: indica che l'utente ha rifiutato le emittenti proposte.
Se
resultCode
èRESULT_OK
, i datiIntent
contengono il valore aggiuntivoEXTRA_WIFI_NETWORK_RESULT_LIST
, che contiene un array di codici di risultato che indicano se le singole configurazioni sono state salvate correttamente. I possibili codici di risultato sono:ADD_WIFI_RESULT_SUCCESS
: configurazione aggiunta o aggiornata correttamente.ADD_WIFI_RESULT_ADD_OR_UPDATE_FAILED
: errore durante il tentativo di aggiungere la configurazione, ad esempio a causa di una configurazione con formato non corretto.ADD_WIFI_RESULT_ALREADY_EXISTS
: la configurazione richiesta esisteva già, pertanto non è stata necessaria alcuna azione.
Se la richiesta ha esito positivo, la piattaforma attiva una connessione a una delle reti appena salvate.
Esempio di codice
Il seguente esempio di codice mostra come salvare una configurazione di una rete o di 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
}
}
}