Android 13 이상을 실행하는 기기에서 Android는 처음 사용 시 신뢰 (TOFU) 인증 방식(RFC7435)을 지원합니다. 이는 사용자가 서버에 사용되는 루트 CA를 설치하고 저장된 네트워크에 도메인 이름을 설정함으로써 엔터프라이즈(EAP) 네트워크를 신뢰할 수 있는 방법입니다. TOFU를 사용하면 사용자가 엔터프라이즈 네트워크에 최초로 연결할 때 기기가 인증되지 않은 공개 키를 가져오고 후속 연결을 위해 이 키를 유지할 수 있습니다.
배경
비밀번호만 있으면 되는 개인 네트워크와 달리 엔터프라이즈 네트워크에서는 PKI(공개 키 인프라) 인증을 사용하므로 클라이언트가 인증서를 사전 설치해야 합니다. Android 11 이하의 경우 사용자는 네트워크 설정에서 서버 CA 인증서에 확인하지 않음 옵션을 선택하여 서버 측 인증서 유효성 검사를 우회할 수 있습니다. 그러나 보안을 강화하고 WPA R2 사양을 준수하고자 Android 12에는 엔터프라이즈 네트워크가 서버 인증서의 유효성을 검사하도록 하는 요구사항이 도입되었습니다. 이 추가 요구사항으로 인해 사용자가 이러한 네트워크에 CA 인증서를 설치해야 하므로 일종의 장벽이 생겼습니다. TOFU는 사용자가 루트 CA를 수락하기만 하면 PKI 기반 엔터프라이즈 네트워크에 연결되는 방법을 제공합니다.
기능 동작
사용자가 이미 설치된 인증된 공개 키가 없는 엔터프라이즈 네트워크에 연결할 경우 TOFU를 지원하는 기기는 다음과 같은 동작을 보입니다.
Wi-Fi 선택도구를 통해 새 네트워크에 연결
Wi-Fi 선택도구에서 새 엔터프라이즈 네트워크를 선택합니다.
네트워크가 신뢰할 수 있는 것인지 확인하라는 대화상자(그림 1)가 기기에 표시됩니다.
네트워크 연결을 수락하려면 예, 연결을 탭하고 거부하려면 연결 안 함을 탭합니다.
예, 연결을 탭하면 기기에서 자동으로 보안 매개변수를 구성하고 네트워크에 연결하며 네트워크 자동 연결을 사용 설정합니다.
연결 안 함을 탭하면 기기가 네트워크에서 연결 해제되고 네트워크 자동 연결이 사용 중지됩니다.
그림 1. TOFU 기능 대화상자
자동 연결이 사용 설정된 기존 네트워크에 연결
자동 연결이 사용 설정되어 있지만 유효한 CA 인증서가 없는 엔터프라이즈 네트워크에 연결되면 기기가 자동으로 연결된 후 고정(닫을 수 없는) 알림을 표시합니다.
알림을 탭합니다.
네트워크가 신뢰할 수 있는 것인지 확인하라는 대화상자(그림 1)가 기기에 표시됩니다.
네트워크 연결을 수락하려면 예, 연결을 탭하고 거부하려면 연결 안 함을 탭합니다.
예, 연결을 탭하면 기기에서 자동으로 보안 매개변수를 구성하고 네트워크에 연결하며 네트워크 자동 연결을 사용 설정합니다.
연결 안 함을 탭하면 기기가 네트워크에서 연결 해제되고 네트워크 자동 연결이 사용 중지됩니다.
구현
TOFU 기능을 지원하려면 Android 오픈소스 프로젝트(AOSP)의 /hardware/interfaces/wifi/supplicant/aidl/android/hardware/wifi/supplicant
에서 제공되는 서플리컨트 HAL을 구현합니다.
Android 13에서 앱에 사용할 수 있는 공개 API는 다음과 같습니다.
WifiManager#isTrustOnFirstUseSupported()
: 기기가 TOFU를 지원하는지를 나타냅니다.WifiEnterpriseConfig#enableTrustOnFirstUse(boolean)
: TOFU를 사용 설정합니다.WifiEnterpriseConfig#isTrustOnFirstUseEnabled()
: TOFU의 사용 설정 여부를 나타냅니다.
유효성 검사
기기에서 TOFU 구현의 유효성을 검사하려면 다음 테스트를 사용하세요.
- CTS:
CtsWifiTestCases
- VTS:
VtsHalWifiSupplicantStaNetworkTargetTest