डिवाइस पर दिखने वाले वाई-फ़ाई ऐक्सेस पॉइंट की सूची पाने के लिए, WifiManager API से मिली वाई-फ़ाई स्कैनिंग की सुविधाओं का इस्तेमाल किया जा सकता है.
वाई-फ़ाई स्कैनिंग की प्रोसेस
स्कैन करने की प्रोसेस के तीन चरण होते हैं:
SCAN_RESULTS_AVAILABLE_ACTION
के लिए ब्रॉडकास्ट लिसनर रजिस्टर करें. इसे तब कॉल किया जाता है, जब स्कैन के अनुरोध पूरे हो जाते हैं. साथ ही, यह अनुरोधों के पूरे होने/पूरे न होने की स्थिति की जानकारी देता है. Android 10 (एपीआई लेवल 29) और इसके बाद के वर्शन वाले डिवाइसों के लिए, यह ब्रॉडकास्ट तब भेजा जाएगा, जब प्लैटफ़ॉर्म या अन्य ऐप्लिकेशन, डिवाइस पर पूरा वाई-फ़ाई स्कैन करेंगे. ऐप्लिकेशन, ब्रॉडकास्ट का इस्तेमाल करके, डिवाइस पर स्कैन पूरा होने की सभी सूचनाएं सुन सकते हैं. इसके लिए, उन्हें खुद स्कैन करने की ज़रूरत नहीं होती.WifiManager.startScan()
का इस्तेमाल करके, स्कैन का अनुरोध करें. इस तरीके की, आइटम लौटाने की स्थिति ज़रूर देखें. इसकी वजह यह है कि कॉल न हो पाने की इनमें से कोई भी वजह हो सकती है:- कम समय में बहुत ज़्यादा स्कैन करने की वजह से, स्कैन करने के अनुरोध रोके जा सकते हैं.
- डिवाइस कुछ समय से इस्तेमाल में नहीं है और स्कैन करने की सुविधा बंद है.
- वाई-फ़ाई हार्डवेयर, स्कैन न हो पाने की जानकारी देता है.
WifiManager.getScanResults()
का इस्तेमाल करके, स्कैन के नतीजे पाएं. स्कैन के नतीजे, हाल ही में अपडेट किए गए नतीजे होते हैं. अगर आपका मौजूदा स्कैन पूरा नहीं हुआ है या सफल नहीं हुआ है, तो हो सकता है कि ये नतीजे किसी पिछले स्कैन के हों. इसका मतलब है कि अगर आपनेSCAN_RESULTS_AVAILABLE_ACTION
का ब्रॉडकास्ट मिलने से पहले, इस तरीके को कॉल किया है, तो आपको स्कैन के पुराने नतीजे मिल सकते हैं.
नीचे दिए गए कोड में, इन चरणों को लागू करने का उदाहरण दिया गया है:
Kotlin
val wifiManager = context.getSystemService(Context.WIFI_SERVICE) as WifiManager val wifiScanReceiver = object : BroadcastReceiver() { override fun onReceive(context: Context, intent: Intent) { val success = intent.getBooleanExtra(WifiManager.EXTRA_RESULTS_UPDATED, false) if (success) { scanSuccess() } else { scanFailure() } } } val intentFilter = IntentFilter() intentFilter.addAction(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION) context.registerReceiver(wifiScanReceiver, intentFilter) val success = wifiManager.startScan() if (!success) { // scan failure handling scanFailure() } .... private fun scanSuccess() { val results = wifiManager.scanResults ... use new scan results ... } private fun scanFailure() { // handle failure: new scan did NOT succeed // consider using old scan results: these are the OLD results! val results = wifiManager.scanResults ... potentially use older scan results ... }
Java
WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE); BroadcastReceiver wifiScanReceiver = new BroadcastReceiver() { @Override public void onReceive(Context c, Intent intent) { boolean success = intent.getBooleanExtra( WifiManager.EXTRA_RESULTS_UPDATED, false); if (success) { scanSuccess(); } else { // scan failure handling scanFailure(); } } }; IntentFilter intentFilter = new IntentFilter(); intentFilter.addAction(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION); context.registerReceiver(wifiScanReceiver, intentFilter); boolean success = wifiManager.startScan(); if (!success) { // scan failure handling scanFailure(); } .... private void scanSuccess() { List<ScanResult> results = wifiManager.getScanResults(); ... use new scan results ... } private void scanFailure() { // handle failure: new scan did NOT succeed // consider using old scan results: these are the OLD results! List<ScanResult> results = wifiManager.getScanResults(); ... potentially use older scan results ... }
पाबंदियां
Android 8.0 (एपीआई लेवल 26) में, अनुमतियों और वाई-फ़ाई स्कैन की अनुमति वाली फ़्रीक्वेंसी से जुड़ी पाबंदियां जोड़ी गई हैं.
नेटवर्क की परफ़ॉर्मेंस, सुरक्षा, और बैटरी लाइफ़ को बेहतर बनाने के लिए, Android 9 (एपीआई लेवल 28) में अनुमति से जुड़ी ज़रूरी शर्तों को सख्त किया गया है. साथ ही, वाई-फ़ाई स्कैन की फ़्रीक्वेंसी को भी सीमित किया गया है.
अनुमतियां
Android 8.0 और Android 8.1:
WifiManager.getScanResults()
को कॉल करने के लिए, इनमें से किसी एक अनुमति की ज़रूरत होती है:
अगर कॉल करने वाले ऐप्लिकेशन के पास इनमें से कोई भी अनुमति नहीं है, तो कॉल SecurityException
के साथ पूरा नहीं होगा.
इसके अलावा, Android 8.0 (एपीआई लेवल 26) और उसके बाद के वर्शन वाले डिवाइसों पर, अपने ऐप्लिकेशन की ओर से आस-पास मौजूद साथी डिवाइसों को स्कैन करने के लिए, CompanionDeviceManager
का इस्तेमाल किया जा सकता है. इसके लिए, जगह की जानकारी की अनुमति की ज़रूरत नहीं होती. इस विकल्प के बारे में ज़्यादा जानने के लिए, कंपैनियन डिवाइस को दूसरे डिवाइस से जोड़ना देखें.
Android 9:
WifiManager.startScan()
पर कॉल करने के लिए, इनमें से सभी शर्तें पूरी होनी चाहिए:
- आपके ऐप्लिकेशन के पास
ACCESS_FINE_LOCATION
याACCESS_COARSE_LOCATION
अनुमति हो. - आपके ऐप्लिकेशन के पास
CHANGE_WIFI_STATE
अनुमति हो. - डिवाइस पर जगह की जानकारी की सेटिंग चालू हो (सेटिंग > जगह की जानकारी में जाकर).
Android 10 (एपीआई लेवल 29) और उसके बाद के वर्शन:
WifiManager.startScan()
पर कॉल करने के लिए, इनमें से सभी शर्तें पूरी होनी चाहिए:
- अगर आपका ऐप्लिकेशन, Android 10 (एपीआई लेवल 29) SDK या उसके बाद के वर्शन को टारगेट करता है, तो आपके ऐप्लिकेशन के पास
ACCESS_FINE_LOCATION
अनुमति है. - अगर आपका ऐप्लिकेशन, Android 10 (एपीआई लेवल 29) से नीचे के SDK टूल को टारगेट कर रहा है, तो आपके ऐप्लिकेशन के पास
ACCESS_COARSE_LOCATION
याACCESS_FINE_LOCATION
की अनुमति है. - आपके ऐप्लिकेशन के पास
CHANGE_WIFI_STATE
अनुमति हो. - डिवाइस पर जगह की जानकारी की सेटिंग चालू हो (सेटिंग > जगह की जानकारी में जाकर).
WifiManager.getScanResults()
को कॉल करने के लिए, पक्का करें कि ये सभी शर्तें पूरी हों:
- अगर आपका ऐप्लिकेशन Android 10 (एपीआई लेवल 29) SDK या उसके बाद के वर्शन को टारगेट करता है, तो आपके ऐप्लिकेशन के पास
ACCESS_FINE_LOCATION
अनुमति है. - अगर आपका ऐप्लिकेशन, Android 10 (एपीआई लेवल 29) से पहले के SDK टूल को टारगेट कर रहा है, तो आपके ऐप्लिकेशन के पास
ACCESS_COARSE_LOCATION
याACCESS_FINE_LOCATION
अनुमति होनी चाहिए. - आपके ऐप्लिकेशन के पास
ACCESS_WIFI_STATE
अनुमति हो. - डिवाइस पर जगह की जानकारी की सेटिंग चालू हो (सेटिंग > जगह की जानकारी में जाकर).
अगर कॉलिंग ऐप्लिकेशन इन सभी ज़रूरी शर्तों को पूरा नहीं करता है, तो SecurityException
का इस्तेमाल करके कॉल नहीं किया जा सकेगा.
थ्रॉटलिंग
WifiManager.startScan()
का इस्तेमाल करने वाले स्कैन की फ़्रीक्वेंसी पर ये सीमाएं लागू होती हैं.
Android 8.0 और Android 8.1:
बैकग्राउंड में चलने वाला हर ऐप्लिकेशन, 30 मिनट में एक बार स्कैन कर सकता है.
Android 9:
फ़ोरग्राउंड में चलने वाले हर ऐप्लिकेशन को दो मिनट की अवधि में चार बार स्कैन किया जा सकता है. इससे, कम समय में कई स्कैन किए जा सकते हैं.
बैकग्राउंड में चल रहे सभी ऐप्लिकेशन, 30 मिनट की अवधि में एक बार स्कैन कर सकते हैं.
Android 10 और उसके बाद वाले वर्शन:
Android 9 में लागू होने वाली थ्रॉटलिंग की वही सीमाएं लागू होती हैं. स्थानीय टेस्टिंग के लिए, थ्रॉटलिंग को बंद करने के लिए, डेवलपर के पास एक नया विकल्प है. इसके लिए, डेवलपर के लिए विकल्प > नेटवर्क > वाई-फ़ाई स्कैन थ्रॉटलिंग में जाएं.