WPA3 und Wi‑Fi Enhanced Open

Android 10 unterstützt die Standards Wi-Fi Protected Access Version 3 (WPA3) und Wi-Fi Enhanced Open der Wi-Fi Alliance (WFA). Weitere Informationen finden Sie auf der WFA-Website unter Security.

WPA3 ist ein neuer WFA-Sicherheitsstandard für private und Unternehmensnetzwerke. Er soll die allgemeine WLAN-Sicherheit durch moderne Sicherheitsalgorithmen und stärkere Chiffrierverfahren verbessern. WPA3 besteht aus zwei Teilen:

  • WPA3-Personal:Verwendet die Simultaneous Authentication of Equals (SAE) anstelle des Pre-Shared Key (PSK) und bietet Nutzern so einen stärkeren Schutz vor Angriffen wie Offline-Wörterbuchangriffen, Schlüsselwiederherstellung und Nachrichtenmanipulation.
  • WPA3-Enterprise:Bietet stärkere Authentifizierungs- und Link-Layer-Verschlüsselungsmethoden sowie einen optionalen 192-Bit-Sicherheitsmodus für sensible Sicherheitsumgebungen.

Wi-Fi Enhanced Open ist ein neuer WFA-Sicherheitsstandard für öffentliche Netzwerke, der auf der Opportunistic Wireless Encryption (OWE) basiert. Er bietet Verschlüsselung und Datenschutz in offenen, nicht passwortgeschützten Netzwerken in Bereichen wie Cafés, Hotels, Restaurants und Bibliotheken. Enhanced Open bietet keine Authentifizierung.

WPA3 und Wi-Fi Enhanced Open verbessern die allgemeine WLAN-Sicherheit und bieten mehr Datenschutz und Robustheit gegen bekannte Angriffe. Da viele Geräte diese Standards noch nicht unterstützen oder noch keine Software-Upgrades erhalten haben, um diese Funktionen zu unterstützen, hat die WFA die folgenden Übergangsmodi vorgeschlagen:

  • WPA2/WPA3-Übergangsmodus:Der bereitstellende Zugangspunkt unterstützt gleichzeitig die Standards WPA2 und WPA3. In diesem Modus verwenden Android 10-Geräte WPA3, um eine Verbindung herzustellen, und Geräte mit Android 9 oder niedriger verwenden WPA2, um eine Verbindung zum selben Zugangspunkt herzustellen.
  • WPA2/WPA3-Enterprise-Übergangsmodus:Der bereitstellende Zugangspunkt unterstützt gleichzeitig die Standards WPA2-Enterprise und WPA3-Enterprise.
  • OWE-Übergangsmodus:Der bereitstellende Zugangspunkt unterstützt gleichzeitig OWE und offene Standards. In diesem Modus verwenden Android 10-Geräte OWE, um eine Verbindung herzustellen, und Geräte mit Android 9 oder niedriger stellen ohne Verschlüsselung eine Verbindung zum selben Zugangspunkt her.

Android 12 unterstützt die Transition Disable-Anzeige, einen Mechanismus, der ein Gerät anweist, WPA2 nicht zu verwenden und stattdessen WPA3 zu nutzen. Wenn ein Gerät diese Anzeige erhält, verwendet es WPA3, um eine Verbindung zu einem WPA3-Netzwerk herzustellen, das einen Übergangsmodus unterstützt. Android 12 unterstützt auch den WPA3-Hash-to-Element-Authentifizierungsaustausch (H2E). Weitere Informationen finden Sie unter der WPA3-Spezifikation.

WPA3 und Wi-Fi Enhanced Open werden nur im Clientmodus unterstützt.

Implementierung

Implementieren Sie die Supplicant HAL-Schnittstelle, um WPA3 und Wi-Fi Enhanced Open zu unterstützen. Ab Android 13 verwendet die Schnittstelle die Android Interface Definition Language (AIDL) für die HAL-Definition. Bei Versionen vor Android 13 verwenden Schnittstellen und Anbieterpartitionen die HAL Interface Definition Language (HIDL). Die HIDL-Schnittstelle finden Sie unter hardware/interfaces/wifi/supplicant/1.3/ und die AIDL-Schnittstelle unter hardware/interfaces/wifi/supplicant/aidl/.

Folgendes ist erforderlich, um WPA3 und OWE zu unterstützen:

  • Linux-Kernel-Patches zur Unterstützung von SAE und OWE
    • cfg80211
    • nl80211
  • wpa_supplicant mit Unterstützung für SAE, SUITEB192 und OWE
  • WLAN-Treiber mit Unterstützung für SAE, SUITEB192 und OWE
  • WLAN-Firmware mit Unterstützung für SAE, SUITEB192 und OWE
  • WLAN-Chip mit Unterstützung für WPA3 und OWE

In Android 10 sind öffentliche API-Methoden verfügbar, mit denen Apps die Geräteunterstützung für diese Funktionen ermitteln können:

WifiConfiguration.java enthält neue Schlüsselverwaltungstypen sowie paarweise Chiffren, Gruppenchiffren, Gruppenverwaltungschiffren und Suite B-Chiffren, die für OWE, WPA3-Personal und WPA3-Enterprise erforderlich sind.

WPA3 und Wi-Fi Enhanced Open aktivieren

So aktivieren Sie WPA3-Personal, WPA3-Enterprise und Wi-Fi Enhanced Open im Android-Framework:

  • WPA3-Personal: Fügen Sie die CONFIG_SAE Kompilierungsoption in die wpa_supplicant Konfigurationsdatei ein.

    # WPA3-Personal (SAE)
    CONFIG_SAE=y
    
  • WPA3-Enterprise: Fügen Sie die Kompilierungsoptionen CONFIG_SUITEB192 und CONFIG_SUITEB in die Konfigurationsdatei wpa_supplicant ein.

    # WPA3-Enterprise (SuiteB-192)
    CONFIG_SUITEB=y
    CONFIG_SUITEB192=y
    
  • Wi-Fi Enhanced Open:Fügen Sie die Kompilierungsoption CONFIG_OWE in die Konfigurationsdatei wpa_supplicant ein.

    # Opportunistic Wireless Encryption (OWE)
    # Experimental implementation of draft-harkins-owe-07.txt
    CONFIG_OWE=y
    

Wenn WPA3-Personal, WPA3-Enterprise oder Wi-Fi Enhanced Open nicht aktiviert sind, können Nutzer diese Arten von Netzwerken nicht manuell hinzufügen, scannen oder eine Verbindung zu ihnen herstellen.

Validierung

Führen Sie die folgenden Tests aus, um Ihre Implementierung zu testen.

Einheitentests

Führen Sie SupplicantStaIfaceHalTest aus, um das Verhalten der Capability Flags für WPA3 und OWE zu prüfen.

atest SupplicantStaIfaceHalTest

Führen Sie WifiManagerTest aus, um das Verhalten der öffentlichen APIs für diese Funktion zu prüfen.

atest WifiManagerTest

VTS-Tests

Wenn die HIDL-Schnittstelle implementiert ist, führen Sie Folgendes aus:

atest VtsHalWifiSupplicantV1_3TargetTest

Wenn die AIDL-Schnittstelle implementiert ist, führen Sie Folgendes aus:

atest VtsHalWifiSupplicantStaIfaceTargetTest