Android 11 (एसडीके लेवल 30) और उसके बाद के वर्शन पर, ऐप्लिकेशन android.provider.Settings.ACTION_WIFI_ADD_NETWORKS
इंटेंट का इस्तेमाल करके, उपयोगकर्ता को एक या उससे ज़्यादा सेव किए गए नए नेटवर्क या Passpoint कॉन्फ़िगरेशन जोड़ने के लिए गाइड कर सकते हैं. यह एपीआई, सेव किए गए मौजूदा कॉन्फ़िगरेशन में बदलाव करने के लिए भी इसी तरह काम करता है.
किसी नेटवर्क या Passpoint कॉन्फ़िगरेशन को सेव करने के लिए, यह तरीका अपनाएं:
ACTION_WIFI_ADD_NETWORKS
इंटेंट बनाएं.WifiNetworkSuggestion.Builder
का इस्तेमाल करके, एक या उससे ज़्यादा कॉन्फ़िगरेशन बनाएं. ध्यान दें किWifiNetworkSuggestion
का इस्तेमाल करने के बावजूद, यह इंटेंट एपीआई, सुझाव एपीआई से जुड़ा नहीं है.कॉन्फ़िगरेशन की ऐसी ऐरे सूची बनाएं जिसे पार्सल किया जा सके. साथ ही, उसे
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
: कॉन्फ़िगरेशन जोड़ने के दौरान गड़बड़ी, जैसे कि गलत तरीके से कॉन्फ़िगरेशन बनाने की वजह से.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
}
}
}