ב-Android מגרסה 11 ואילך (SDK ברמה 30 ואילך), אפליקציות יכולות להשתמש בכוונה android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
כדי להנחות את המשתמש להוסיף רשתות חדשות שמורות או הגדרות Passpoint חדשות. ה-API פועל גם כפי שהוא כדי לשנות הגדרות קיימות שנשמרו.
כדי לשמור הגדרות של רשת או של Passpoint:
יוצרים כוונת רכישה מסוג
ACTION_WIFI_ADD_NETWORKS
.יוצרים הגדרה אחת או יותר באמצעות
WifiNetworkSuggestion.Builder
. חשוב לזכור שגם אם אתם משתמשים ב-WifiNetworkSuggestion
, ממשק ה-API הזה לא קשור ל-Suggestion API.יוצרים רשימת מערך של ההגדרות שניתנות לחלוקה, ומצרפים אותה ל-intent באמצעות ה-extra
EXTRA_WIFI_NETWORK_LIST
.מריצים את הפקודה
Activity.startActivityForResult()
ומעבירים את הכוונה.ממתינים לתוצאה באמצעות הפונקציה החוזרת
Activity.onActivityResult()
.הערך של
resultCode
יכול להיות אחד מהערכים הבאים:Activity.RESULT_OK
: המשמעות היא שהמשתמש אישר את הרשתות המוצעות ושמר אותן.Activity.RESULT_CANCELED
: המשמעות היא שהמשתמש דחה את הרשתות שהוצעו.
אם הערך של
resultCode
הואRESULT_OK
, הנתוניםIntent
מכילים את ה-extraEXTRA_WIFI_NETWORK_RESULT_LIST
, שמכיל מערך של קודי תוצאות שמציינים אם הגדרות מסוימות נשמרו בהצלחה. קודי התוצאות האפשריים הם: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
}
}
}