Android: определить тип безопасности сетей Wi-Fi в зоне действия (без подключения к ним) - PullRequest
22 голосов
/ 29 июля 2011

Я могу перечислить все сети Wi-Fi в диапазоне (используя startScan + SCAN_RESULTS_AVAILABLE_ACTION + getScanResults) и получить их значения SSID и BSSID, но я не могу понять, как определить тип безопасности каждой сети.

В моем основном объекте:

    IntentFilter intentFilter = new IntentFilter();
    intentFilter.addAction(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION);
    registerReceiver(scanReceiver, intentFilter);
    ((WifiManager)getSystemService(Context.WIFI_SERVICE)).startScan();

В моем объекте scanReceiver:

public void onReceive(Context c, Intent intent) {
    if (WifiManager.SCAN_RESULTS_AVAILABLE_ACTION.equals(intent.getAction())){
        mainObject.scanComplete();
    }
}

И снова в моем главном объекте:

public void scanComplete()
{
    List<ScanResult> networkList = ((WifiManager)getSystemService.(Context.WIFI_SERVICE)).getScanResults();
    for (ScanResult network : networkList)
    {
        <do stuff>
    }
}

Код работает, если в конечном итоге вызывается scanComplete, и я могу успешно перечислить все близлежащие сети Wi-Fi и получить их SSID и BSSID, но я не могу понять, как определить их тип безопасности.

Есть ли способ сделать это?

Заранее спасибо.

Ответы [ 4 ]

35 голосов
/ 24 октября 2013

Я думаю, вы можете найти его в исходном коде Settings.apk.

Сначала вы должны позвонить wifiManager.getConfiguredNetworks() или wifiManager.getScanResults(), затем используйте два метода ниже: (найдите их в AccessPoint class "com.android.settings.wifi"):

static int getSecurity(WifiConfiguration config) {
    if (config.allowedKeyManagement.get(KeyMgmt.WPA_PSK)) {
        return SECURITY_PSK;
    }
    if (config.allowedKeyManagement.get(KeyMgmt.WPA_EAP) ||
            config.allowedKeyManagement.get(KeyMgmt.IEEE8021X)) {
        return SECURITY_EAP;
    }
    return (config.wepKeys[0] != null) ? SECURITY_WEP : SECURITY_NONE;
}

static int getSecurity(ScanResult result) {
    if (result.capabilities.contains("WEP")) {
        return SECURITY_WEP;
    } else if (result.capabilities.contains("PSK")) {
        return SECURITY_PSK;
    } else if (result.capabilities.contains("EAP")) {
        return SECURITY_EAP;
    }
    return SECURITY_NONE;
}

Надеюсь, это полезно.

24 голосов
/ 11 августа 2011

Вам необходимо проанализировать строку возможностей ScanResult в методе scanComplete.Согласно документации для разработчиков Android ,:

ScanResult.capabilities описывает схемы аутентификации, управления ключами и шифрования, поддерживаемые точкой доступа.

Возможно, вы сможете использовать - или, по крайней мере, использовать в качестве примера - статические вспомогательные методы, доступные в классе AccessPointState.

7 голосов
/ 05 сентября 2011

Большое спасибо, ... вы сделали мой день ...

Мне есть что добавить здесь. Без сканирования сетей можно получить текущую подключенную информацию о конфигурации Wi-Fi (особенно шифрование и управление ключами) следующим образом:

WifiManager wifi = (WifiManager) getSystemService(Context.WIFI_SERVICE);
List<ScanResult> networkList = wifi.getScanResults();
if (networkList != null) {
    for (ScanResult network : networkList)
    {
        String Capabilities =  network.capabilities;        
        Log.w (TAG, network.SSID + " capabilities : " + Capabilities);
    }
}
1 голос
/ 23 августа 2011

Тип безопасности каждой сети указан в столбце «Возможности» результатов сканирования.

Итак, чтобы получить тип безопасности для вас, добавьте это в свою часть кода.

public void scanComplete()
{
    List<ScanResult> networkList = ((WifiManager)getSystemService.(Context.WIFI_SERVICE)).getScanResults();
    for (ScanResult network : networkList)
    {
        String Capabilities =  network.capabilities;

        //Then you could add some code to check for a specific security type. 
        if(Capabilities.contains("WPA"))
     {
          // We know there is WPA encryption
         }
        else if(Capabilities.contains("WEP"))
         {
         // We know there is WEP encryption
         }
        else
         { 
         // Another type of security scheme, open wifi, captive portal, etc..
         }

    }
}

В любом случае, вот небольшой исходный код. Я бы полностью рекомендовал ответ Айя, поскольку он является исключительным и более полным.

...