El conjunto de documentos para este producto aspira al uso de un lenguaje no discriminatorio. A los fines de esta documentación, "no discriminatorio" se refiere al lenguaje que no implica discriminación por motivos de edad, discapacidad, género, identidad de raza, identidad étnica, orientación sexual, nivel socioeconómico e interseccionalidad. Puede haber excepciones en la documentación debido al lenguaje que se encuentra ya en las interfaces de usuario del software del producto, el lenguaje utilizado en función de la documentación de la RFP o el lenguaje utilizado por un producto de terceros al que se hace referencia. Obtenga más información sobre cómo Cisco utiliza el lenguaje inclusivo.
Cisco ha traducido este documento combinando la traducción automática y los recursos humanos a fin de ofrecer a nuestros usuarios en todo el mundo contenido en su propio idioma. Tenga en cuenta que incluso la mejor traducción automática podría no ser tan precisa como la proporcionada por un traductor profesional. Cisco Systems, Inc. no asume ninguna responsabilidad por la precisión de estas traducciones y recomienda remitirse siempre al documento original escrito en inglés (insertar vínculo URL).
Este documento describe los tipos de roaming inalámbrico y de seguridad rápida disponibles para las LAN inalámbricas (WLAN) IEEE 802.11 en Unified Wireless Network (CUWN).
Cisco recomienda que tenga conocimiento sobre estos temas:
La información de este documento se basa en la versión 7.4 del software Cisco WLAN Controller.
La información que contiene este documento se creó a partir de los dispositivos en un ambiente de laboratorio específico. Todos los dispositivos que se utilizan en este documento se pusieron en funcionamiento con una configuración verificada (predeterminada). Si tiene una red en vivo, asegúrese de entender el posible impacto de cualquier comando.
La información de este documento se basa en la versión 7.4 del software Cisco WLAN Controller, pero la mayoría de las salidas y comportamientos de depuración descritos pueden aplicarse a cualquier versión de software que admita los métodos descritos. Los detalles de todos los métodos explicados aquí siguen siendo los mismos en los códigos de Cisco WLAN Controller posteriores (hasta la versión 8.3 en el momento en que se actualizó este artículo).
Este documento describe los diferentes tipos de itinerancia inalámbrica y los métodos de itinerancia rápida y segura disponibles para las LAN inalámbricas (WLAN) IEEE 802.11 compatibles con Cisco Unified Wireless Network (CUWN).
El documento no proporciona todos los detalles sobre cómo funciona cada método o cómo se configuran. El objetivo principal de este documento es describir las diferencias entre las diversas técnicas disponibles, sus ventajas y limitaciones, y el intercambio de tramas en cada método. Se proporcionan ejemplos de depuraciones del controlador WLAN (WLC) y se utilizan imágenes de paquetes inalámbricos para analizar y explicar los eventos que se producen para cada método de itinerancia descrito.
Antes de que se proporcione una descripción de los diferentes métodos de itinerancia de seguridad rápida disponibles para las WLAN, es importante comprender cómo funciona el proceso de asociación WLAN y cómo se produce un evento de itinerancia regular cuando no hay ninguna seguridad configurada en el identificador del conjunto de servicios (SSID).
Cuando un cliente inalámbrico 802.11 se conecta a un punto de acceso (AP), antes de que comience a pasar tráfico (tramas de datos inalámbricos), primero debe pasar el proceso de autenticación de sistema abierto 802.11 básico. A continuación, debe completarse el proceso de asociación. El proceso de autenticación de sistema abierto es como una conexión por cable en el AP que el cliente selecciona. Este es un punto muy importante, ya que siempre es el cliente inalámbrico el que selecciona qué AP se prefiere, y basa la decisión en múltiples factores que varían entre los proveedores. Esta es la razón por la que el cliente comienza este proceso enviando la trama de autenticación al AP seleccionado, como se muestra más adelante en este documento. El AP no puede solicitar que usted establezca una conexión.
Una vez que el proceso de autenticación de sistema abierto se completa con éxito con una respuesta del AP ("cable conectado"), el proceso de asociación esencialmente termina la negociación de capa 2 (L2) 802.11 que establece el link entre el cliente y el AP. El AP asigna un ID de asociación al cliente si la conexión es exitosa, y lo prepara para pasar el tráfico o realizar un método de seguridad de nivel superior si está configurado en el SSID. El proceso de autenticación de sistema abierto consta de dos tramas de administración, así como el proceso de asociación. Las tramas de autenticación y asociación son tramas de administración inalámbrica, no tramas de datos, que son básicamente las utilizadas para el proceso de conexión con el AP.
A continuación se muestra una imagen de las tramas inalámbricas aéreas para este proceso:
Nota: Si desea obtener información sobre el rastreo inalámbrico 802.11 y sobre los filtros/colores utilizados en Wireshark para las imágenes que aparecen en este documento, visite la publicación de la Comunidad de soporte de Cisco llamada 802.11 Sniffer image Analysis.
El cliente inalámbrico comienza con la trama de autenticación y el AP responde con otra trama de autenticación. El cliente luego envía la trama de Solicitud de asociación y el AP termina en una respuesta con la trama de Respuesta de asociación. Como se muestra en los paquetes DHCP, una vez que se pasan los procesos de autenticación y asociación del sistema abierto 802.11, el cliente comienza a pasar tramas de datos. En este caso, no hay ningún método de seguridad configurado en el SSID, por lo que el cliente comienza inmediatamente a enviar tramas de datos (en este caso, DHCP) que no están cifradas.
Como se muestra más adelante en este documento, si se habilita la seguridad en el SSID, existen tramas de entrada en contacto de autenticación y cifrado de nivel superior para el método de seguridad específico, justo después de la respuesta de asociación y antes de que se envíen las tramas de datos de tráfico del cliente, como DHCP, el protocolo de resolución de direcciones (ARP) y los paquetes de aplicaciones, que se cifran. Las tramas de datos sólo se pueden enviar hasta que el cliente esté totalmente autenticado y se negocien las claves de cifrado, según el método de seguridad configurado.
Basado en la imagen anterior, aquí están los mensajes que usted ve en las salidas del comando debug client del WLC cuando el cliente inalámbrico comienza una nueva asociación a la WLAN:
*apfMsConnTask_0: Jun 21 18:55:14.221: 00:40:96:b7:ab:5c
Association received from mobile on BSSID 84:78:ac:f0:68:d0
!--- This is the Association Request from the wireless client
to the selected AP.
*apfMsConnTask_0: Jun 21 18:55:14.222: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d0
(status 0) ApVapId 1 Slot 0
!--- This is the Association Response from the AP to the client.
Nota: El WLC debug utilizado para las salidas mostradas en este documento es el comando debug client, y los ejemplos sólo muestran algunos mensajes relevantes, no la salida completa. Para obtener más detalles sobre este comando de depuración, consulte el documento Introducción al cliente de depuración en controladores LAN inalámbricos (WLC).
Estos mensajes muestran las tramas de Solicitud de Asociación y Respuesta; las tramas de Autenticación iniciales no se registran en el WLC porque este intercambio de señales ocurre rápidamente en el nivel de AP en el CUWN.
¿Qué información aparece cuando el cliente se desplaza? El cliente siempre intercambia cuatro tramas de administración al establecer una conexión con un AP, que se debe al establecimiento de asociación del cliente o a un evento de roaming. El cliente sólo tiene una conexión establecida a un solo AP a la vez. La única diferencia en el intercambio de tramas entre una nueva conexión a la infraestructura WLAN y un evento de roaming es que las tramas de asociación de un evento de roaming se llaman tramas de reasociación, que indican que el cliente está en realidad en roaming desde otro AP sin intentos de establecer una nueva asociación con la WLAN. Estas tramas pueden contener diferentes elementos que se utilizan para negociar el evento de itinerancia; esto depende de la configuración, pero esos detalles están fuera del alcance de este documento.
Aquí hay un ejemplo del intercambio de tramas:
Estos mensajes aparecen en el resultado de la depuración:
*apfMsConnTask_2: Jun 21 19:02:19.709: 00:40:96:b7:ab:5c
Reassociation received from mobile on BSSID 84:78:ac:f0:2a:90
!--- This is the Reassociation Request from the wireless client
to the selected AP.
*apfMsConnTask_2: Jun 21 19:02:19.710: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:2a:90
(status 0) ApVapId 1 Slot 0
!--- This is the Reassociation Response from the AP to the client.
Como se muestra, el cliente realiza correctamente un evento de roaming después de que se envía la solicitud de reasociación al nuevo AP y recibe la respuesta de reasociación del AP. Dado que el cliente ya tiene una dirección IP, las primeras tramas de datos son para paquetes ARP.
Si espera un evento de itinerancia, pero el cliente envía una Solicitud de asociación en lugar de una Solicitud de reasociación (que puede confirmar a partir de algunas imágenes y depuraciones similares a las explicadas anteriormente en este documento), entonces el cliente no está realmente en itinerancia. El cliente inicia una nueva asociación a la WLAN como si se hubiera producido una desconexión e intenta volver a conectarse desde el principio. Esto puede suceder por varias razones, como cuando un cliente se aleja de las áreas de cobertura y luego encuentra un AP con suficiente calidad de señal para iniciar una asociación, pero normalmente indica un problema del cliente donde el cliente no inicia un evento de roaming debido a controladores, firmware o problemas de software.
Nota: Puede consultar al proveedor del cliente inalámbrico para determinar la causa del problema.
Cuando el SSID se configura con una seguridad de nivel superior L2 sobre la autenticación básica de sistema abierto 802.11, se requieren más tramas para la asociación inicial y cuando se está en roaming. Los dos métodos de seguridad más comunes estandarizados e implementados para WLAN 802.11 se describen en este documento:
Es importante saber que, aunque estos dos métodos (PSK y EAP) autentican/validan los clientes de formas diferentes, ambos utilizan básicamente las mismas reglas WPA/WPA2 para el proceso de administración de claves. Tanto si la seguridad es WPA/WPA2-PSK o WPA/WPA2-EAP, el proceso conocido como protocolo de enlace de 4 vías WPA/WPA2 inicia la negociación de clave entre el WLC/AP y el cliente con una clave de sesión maestra (MSK) como material de clave original una vez que el cliente se valida con el método de autenticación específico utilizado.
A continuación se muestra un resumen del proceso:
Cuando WPA-PSK o WPA2-PSK se realiza mediante el protocolo de integridad de clave temporal (TKIP) o el estándar de cifrado avanzado (AES) para el cifrado, el cliente debe pasar por el proceso conocido como protocolo de enlace de 4 vías WPA tanto para la asociación inicial como para la itinerancia. Como se ha explicado anteriormente, se trata básicamente del proceso de gestión de claves utilizado para que WPA/WPA2 derive las claves de encriptación. Sin embargo, cuando se realiza PSK, también se utiliza para verificar que el cliente tiene una clave previamente compartida válida para unirse a la WLAN. Esta imagen muestra el proceso de asociación inicial cuando se realiza WPA o WPA2 con PSK:
Como se muestra, después del proceso de asociación y autenticación del sistema abierto 802.11, hay cuatro tramas EAPOL del protocolo de enlace de 4 vías WPA, que son iniciadas por el AP con el mensaje-1, y terminadas por el cliente con el mensaje-4. Después de una entrada en contacto exitosa, el cliente comienza a pasar tramas de datos (como DHCP), que en este caso se cifran con las claves derivadas de la entrada en contacto de 4 vías (es por esto que no puede ver el contenido real y el tipo de tráfico de las imágenes inalámbricas).
Nota: Las tramas EAPOL se utilizan para transportar todas las tramas de administración de claves y las tramas de autenticación 802.1X/EAP por el aire entre el AP y el cliente; se transmiten como tramas de datos inalámbricas.
Estos mensajes aparecen en los resultados de depuración:
*apfMsConnTask_0: Jun 21 19:30:05.172: 00:40:96:b7:ab:5c
Association received from mobile on BSSID 84:78:ac:f0:68:d1
*apfMsConnTask_0: Jun 21 19:30:05.173: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d1
(status 0) ApVapId 2 Slot 0
!--- The Association handshake is finished.
*dot1xMsgTask: Jun 21 19:30:05.178: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state INITPMK (message 1), replay counter
00.00.00.00.00.00.00.00
!--- Message-1 of the WPA/WPA2 4-Way handshake is sent
from the WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 21 19:30:05.289: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 19:30:05.289: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2)
from mobile 00:40:96:b7:ab:5c
!--- Message-2 of the WPA/WPA2 4-Way handshake is successfully
received from the client.
*Dot1x_NW_MsgTask_4: Jun 21 19:30:05.290: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
!--- Message-3 of the WPA/WPA2 4-Way handshake is sent
from the WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 21 19:30:05.309: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 19:30:05.310: 00:40:96:b7:ab:5c
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile 00:40:96:b7:ab:5c
!--- Message-4 (final message) of the WPA/WPA2 4-Way handshake
is successfully received from the client, which confirms
the installation of the derived keys. They can now be used in
order to encrypt data frames with current AP.
Cuando está en roaming, el cliente básicamente realiza un seguimiento del mismo intercambio de tramas, donde se requiere el protocolo de enlace de 4 vías WPA para derivar nuevas claves de cifrado con el nuevo AP. Esto se debe a razones de seguridad establecidas por el estándar y al hecho de que el nuevo AP no conoce las claves originales. La única diferencia es que hay marcos de reasociación en lugar de marcos de asociación, como se muestra en esta imagen:
Verá los mismos mensajes en los resultados de depuración, pero el primer paquete del cliente es una reasociación en lugar de una asociación, como se ha mostrado y explicado anteriormente.
Cuando se utiliza un método 802.1X/EAP para autenticar a los clientes en un SSID seguro, se requieren aún más tramas antes de que el cliente comience a pasar tráfico. Estas tramas adicionales se utilizan para autenticar las credenciales del cliente y, según el método EAP, puede haber entre cuatro y veinte tramas. Éstos se producen después de la asociación o reasociación, pero antes del protocolo de enlace de 4 vías WPA/WPA2, porque la fase de autenticación deriva la MSK utilizada como la semilla para la generación de la clave de cifrado final en el proceso de gestión de claves (protocolo de enlace de 4 vías).
Esta imagen muestra un ejemplo de las tramas intercambiadas por el aire entre el AP y el cliente inalámbrico en la asociación inicial cuando se realiza WPA con PEAPv0/EAP-MSCHAPv2:
A veces este intercambio muestra más o menos tramas, que depende de múltiples factores, como el método EAP, las retransmisiones debido a problemas, el comportamiento del cliente (como las dos Solicitudes de identidad en este ejemplo, porque el cliente envía un EAPOL START después de que el AP envíe la primera Solicitud de identidad), o si el cliente ya intercambió el certificado con el servidor. Siempre que el SSID se configura para un método 802.1X/EAP, hay más tramas (para la autenticación) y, por lo tanto, se requiere más tiempo antes de que el cliente comience a enviar tramas de datos.
A continuación se muestra un resumen de los mensajes de depuración:
*apfMsConnTask_0: Jun 21 23:41:19.092: 00:40:96:b7:ab:5c
Association received from mobile on BSSID 84:78:ac:f0:68:d8
*apfMsConnTask_0: Jun 21 23:41:19.094: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d8
(status 0) ApVapId 9 Slot 0
!--- The Association handshake is finished.
*dot1xMsgTask: Jun 21 23:41:19.098: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 1)
!--- The EAP Identity Request is sent to the client once it is
associated in order to begin the higher-level authentication
process. This informs the client that an identity to start
this type of 802.1X/EAP authentication must be provided.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.226: 00:40:96:b7:ab:5c
Received EAPOL START from mobile 00:40:96:b7:ab:5c
!--- The wireless client decides to start the EAP authentication
process, and informs the AP with an EAPOL START data frame.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.227: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 2)
!--- WLC/AP sends another EAP Identity Request to the client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.235: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.235: 00:40:96:b7:ab:5c
Received Identity Response (count=2) from mobile 00:40:96:b7:ab:5c
!--- The client responds with an EAP Identity Response on an EAPOL
frame.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.301: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.301: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 3)
!--- Once the WLC/AP sends the client response to the Authentication
Server on a RADIUS Access-Request packet, the server responds
with a RADIUS Access-Challenge in order to officially start the
EAP negotiation, handshake, and authentication with the client
(sometimes with mutual authentication, dependent upon the EAP
method). This response received by the WLC/AP is sent to the client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.344: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.344: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 3, EAP Type 25)
!--- The client responds with an EAP Response on an EAPOL frame, which
is sent to the Authentication Server on a RADIUS Access-Request
packet. The server responds with another RADIUS Access-Challenge.
This process continues, dependent upon the EAP method (the exchange
of certificates when used, the building of TLS tunnels, validation
of client credentials, client validation of server identity when
applicable). Hence, the next few messages are basically the same on
the WLC/AP side, as this acts as a "proxy" between the client and
the Authentication Server exchanges.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.347: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.347: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 4)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.375: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.375: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 4, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.377: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.377: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 5)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.403: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.403: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 5, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.404: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.404: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 6)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.414: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.414: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 6, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.421: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.421: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 7)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.425: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.425: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 7, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.427: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.427: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 8)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.434: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.434: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 8, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.436: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.436: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 9)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.440: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.440: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 9, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.442: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.442: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 10)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.449: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.449: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 10, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.452: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.452: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 11)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.457: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.457: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 11, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.459: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.459: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 13)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.469: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.469: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 13, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.472: 00:40:96:b7:ab:5c
Processing Access-Accept for mobile 00:40:96:b7:ab:5c
!--- The authentication finishes and is successful for this client,
so the RADIUS Server sends a RADIUS Access-Accept to the WLC/AP.
This RADIUS Access-Accept comes with the special attributes
that are assigned to this client (if any are configured on the
Authentication Server for this client). This Access-Accept also
comes with the MSK derived with the client in the EAP
authentication process, so the WLC/AP installs it in order to
initiate the WPA/WPA2 4-Way handshake with the wireless client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.473: 00:40:96:b7:ab:5c
Sending EAP-Success to mobile 00:40:96:b7:ab:5c
(EAP Id 13)
!--- The accept/pass of the authentication is sent to the client as
an EAP-Success message.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.473: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state INITPMK (message 1), replay counter
00.00.00.00.00.00.00.00
!--- Message-1 of the WPA/WPA2 4-Way handshake is sent from the
WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.481: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.481: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2)
from mobile 00:40:96:b7:ab:5c
!--- Message-2 of the WPA/WPA-2 4-Way handshake is successfully
received from the client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.481: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
!--- Message-3 of the WPA/WPA2 4-Way handshake is sent from the
WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.487: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:41:19.487: 00:40:96:b7:ab:5c
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile 00:40:96:b7:ab:5c
!--- Message-4 (final message) of the WPA/WPA2 4-Way handshake
is successfully received from the client, which confirms the
installation of the derived keys. They can now be used in
order to encrypt data frames with the current AP.
Cuando el cliente inalámbrico realiza un roaming regular aquí (el comportamiento normal, sin la implementación de un método de roaming seguro rápido), el cliente debe pasar exactamente por el mismo proceso y realizar una autenticación completa contra el servidor de autenticación, como se muestra en las imágenes. La única diferencia es que el cliente utiliza una Solicitud de Reasociación para informar al nuevo AP que está en realidad en roaming desde otro AP, pero el cliente todavía tiene que pasar por la validación completa y la generación de nueva clave:
Como se muestra, incluso cuando hay menos tramas que en la autenticación inicial (que es causada por múltiples factores, como se mencionó anteriormente), cuando el cliente se traslada a un nuevo AP, la autenticación EAP y los procesos de administración de claves WPA aún deben completarse para continuar pasando tramas de datos (incluso si el tráfico se envió activamente antes del roaming). Por lo tanto, si el cliente tiene una aplicación activa sensible a los retrasos (como aplicaciones de tráfico de voz o aplicaciones sensibles a los tiempos de espera), el usuario puede percibir problemas al desplazarse, como brechas de audio o desconexiones de aplicaciones. Esto depende del tiempo que tarda el proceso en que el cliente continúe enviando o recibiendo tramas de datos. Este retraso puede ser más largo, dependiendo de: el entorno de RF, la cantidad de clientes, el tiempo de ida y vuelta entre el WLC y los LAPs y con el servidor de autenticación, y otras razones.
A continuación se presenta un resumen de los mensajes de depuración para este evento de roaming (básicamente los mismos que los anteriores, por lo que estos mensajes no se describen con más detalle):
*apfMsConnTask_2: Jun 21 23:47:54.872: 00:40:96:b7:ab:5c
Reassociation received from mobile on BSSID 84:78:ac:f0:2a:98
*apfMsConnTask_2: Jun 21 23:47:54.874: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:2a:98
(status 0) ApVapId 9 Slot 0
*dot1xMsgTask: Jun 21 23:47:54.879: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 1)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.895: 00:40:96:b7:ab:5c
Received EAPOL START from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.895: 00:40:96:b7:ab:5c
dot1x - moving mobile 00:40:96:b7:ab:5c intoConnecting
state
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.895: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 2)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.922: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.922: 00:40:96:b7:ab:5c
Received Identity Response (count=2) from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.929: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.929: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 3)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.941: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.941: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 3, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.943: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.943: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 4)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.954: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.954: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 4, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.956: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.957: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 7)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.976: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.976: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 7, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.978: 00:40:96:b7:ab:5c
Processing Access-Accept for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.978: 00:40:96:b7:ab:5c
Sending EAP-Success to mobile 00:40:96:b7:ab:5c
(EAP Id 7)
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.978: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state INITPMK (message 1), replay counter
00.00.00.00.00.00.00.00
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.995: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.995: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2)
from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:54.995: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
*Dot1x_NW_MsgTask_4: Jun 21 23:47:55.005: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 23:47:55.005: 00:40:96:b7:ab:5c
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile 00:40:96:b7:ab:5c
Esta es la forma en que funcionan 802.1X/EAP y la estructura de seguridad WPA/WPA2. Con el fin de evitar el impacto de la aplicación/servicio en los retrasos de un evento de roaming regular, el sector de WiFi desarrolla e implementa varios métodos de roaming rápido seguro para acelerar el proceso de roaming cuando se utiliza seguridad en WLAN/SSID. Los clientes se enfrentan a cierta latencia cuando continúan pasando el tráfico mientras se desplazan entre los AP a través de la implementación de la seguridad de alto nivel en el WLAN. Esto se debe a la autenticación EAP y a los intercambios de tramas de administración de claves requeridos por la configuración de seguridad, como se explicó anteriormente.
Es importante comprender que el término "roaming seguro rápido" es simplemente el término que utiliza el sector en referencia a la implementación de un método o esquema que acelera el proceso de roaming cuando se configura la seguridad en la WLAN. En la siguiente sección se explican los diferentes métodos/esquemas de roaming de seguridad rápida que están disponibles para las WLAN y que son compatibles con CUWN.
Cisco Centralized Key Management (CCKM) es el primer método de roaming rápido y seguro desarrollado e implementado en las WLAN empresariales, creado por Cisco como la solución utilizada para mitigar los retrasos explicados hasta el momento, cuando se utiliza la seguridad 802.1X/EAP en la WLAN. Al tratarse de un protocolo propiedad de Cisco, solo es compatible con los dispositivos de infraestructura WLAN de Cisco y los clientes inalámbricos (de varios proveedores) compatibles con Cisco Compatible Extension (CCX) para CCKM.
CCKM se puede implementar con los distintos métodos de encriptación disponibles para las WLAN, entre los que se incluyen: WEP, TKIP y AES. También es compatible con la mayoría de los métodos de autenticación 802.1X/EAP utilizados para las WLAN, según la versión de CCX admitida por los dispositivos.
Nota: Para obtener una descripción general del contenido de las funciones admitidas por las diferentes versiones de la especificación CCX (que incluye los métodos EAP admitidos), consulte el documento Versiones y funciones de CCX y verifique la versión exacta de CCX admitida por los clientes inalámbricos (si son compatibles con CCX), de modo que pueda confirmar si se puede implementar el método de seguridad que desea utilizar con CCKM.
Esta imagen inalámbrica proporciona un ejemplo de las tramas intercambiadas tras la asociación inicial cuando se realiza CCKM con TKIP como cifrado y PEAPv0/EAP-MSCHAPv2 como método 802.1X/EAP. Básicamente, se trata del mismo intercambio que si se realizara WPA/TKIP con PEAPv0/EAP-MSCHAPv2, pero esta vez CCKM entre el cliente y la infraestructura se negocia de modo que utilicen diferentes jerarquías de claves y métodos de caché para realizar la itinerancia segura rápida cuando el cliente debe desplazarse:
A continuación se muestra un resumen de los mensajes de depuración (con algunos intercambios EAP eliminados para reducir el resultado):
*apfMsConnTask_0: Jun 25 15:41:41.507: 00:40:96:b7:ab:5c
Association received from mobile on BSSID 84:78:ac:f0:68:d3
!--- This is the Association Request from the client.
*apfMsConnTask_0: Jun 25 15:41:41.507: 00:40:96:b7:ab:5c
Processing WPA IE type 221, length 22 for mobile
00:40:96:b7:ab:5c
*apfMsConnTask_0: Jun 25 15:41:41.507: 00:40:96:b7:ab:5c
CCKM: Mobile is using CCKM
!--- The WLC/AP finds an Information Element that claims CCKM
support on the Association request that is sent from the client.
*apfMsConnTask_0: Jun 25 15:41:41.507: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 8
!--- This is the key cache index for this client, which is set temporally.
*apfMsConnTask_0: Jun 25 15:41:41.508: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d3
(status 0) ApVapId 4 Slot 0
!--- The Association Response is sent to the client.
*dot1xMsgTask: Jun 25 15:41:41.513: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 1)
!--- An EAP Identity Request is sent to the client once it is
associated in order to begin the higher-level authentication
process. This informs the client that an identity to start
this type of 802.1X/EAP authentication must be provided.
Further EAP messages are not described, as they are basically
the same as the ones previously-explained.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.536: 00:40:96:b7:ab:5c
Received EAPOL START from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.536: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 2)
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.546: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.546: 00:40:96:b7:ab:5c
Received EAP Response packet with mismatching id
(currentid=2, eapid=1) from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.550: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.550: 00:40:96:b7:ab:5c
Received Identity Response (count=2) from mobile
00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.555: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.555: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 3)
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.594: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.594: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 3, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.840: 00:40:96:b7:ab:5c
Processing Access-Accept for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
Creating a PKC PMKID Cache entry for station 00:40:96:b7:ab:5c
(RSN 0)<br/ >
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 8
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 0
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
CCKM: Create a global PMK cache entry
!--- WLC creates a global PMK cache entry for this client,
which is for CCKM in this case.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
Sending EAP-Success to mobile 00:40:96:b7:ab:5c
(EAP Id 13)
!--- The client is informed of the successful EAP authentication.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.841: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c state
INITPMK(message 1),replay counter 00.00.00.00.00.00.00.00
!--- Message-1 of the initial 4-Way handshake is sent from the
WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2) from mobile
00:40:96:b7:ab:5c
!--- Message-2 of the initial 4-Way handshake is received
successfully from the client.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: 00:40:96:b7:ab:5c
CCKM: Sending cache add
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: CCKM: Sending CCKM PMK
(Version_1) information to mobility group
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: CCKM: Sending CCKM PMK
(Version_2) information to mobility group
!--- The CCKM PMK cache entry for this client is shared with
the WLCs on the mobility group.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.858: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c
state PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
!--- Message-3 of the initial 4-Way handshake is sent from the
WLC/AP to the client.
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.866: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 25 15:41:41.866: 00:40:96:b7:ab:5c Received
EAPOL-key in PTKINITNEGOTIATING state (message 4) from mobile
00:40:96:b7:ab:5c
!--- Message-4 (final message) of this initial 4-Way handshake
is received successfully from the client, which confirms the
installation of the derived keys. They can now be used in order
to encrypt data frames with the current AP.
Con CCKM, la asociación inicial a la WLAN es similar a la WPA/WPA2 normal, donde una MSK (también conocida como clave de sesión de red [NSK]) se deriva mutuamente con el cliente y el servidor RADIUS. Esta clave primaria se envía del servidor al WLC después de una autenticación exitosa, y se almacena en caché como la base para la derivación de todas las claves subsiguientes durante la vida útil de la asociación del cliente con esta WLAN. A partir de aquí, el WLC y el cliente derivan la información semilla que se utiliza para el roaming seguro rápido basado en CCKM, esto pasa a través de un protocolo de enlace de 4 vías similar al de WPA/WPA2, para derivar las claves de cifrado de unidifusión (PTK) y multidifusión/difusión (GTK) con el primer AP.
La gran diferencia se nota cuando se está en roaming. En este caso, el cliente CCKM envía una sola trama de petición de reasociación al AP/WLC (que incluye un MIC y un número aleatorio que aumenta secuencialmente), y proporciona suficiente información (que incluye la nueva dirección MAC del AP -BSSID-) para derivar la nueva PTK. Con esta Solicitud de Reasociación, el WLC y el nuevo AP también tienen suficiente información para derivar la nueva PTK, por lo que simplemente responden con una Respuesta de Reasociación. El cliente ahora puede continuar pasando tráfico, como se muestra en esta imagen:
Aquí está un resumen de las depuraciones del WLC para este evento de roaming:
*apfMsConnTask_2: Jun 25 15:43:33.749: 00:40:96:b7:ab:5c
CCKM: Received REASSOC REQ IE
*apfMsConnTask_2: Jun 25 15:43:33.749: 00:40:96:b7:ab:5c
Reassociation received from mobile on BSSID
84:78:ac:f0:2a:93
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
Processing WPA IE type 221, length 22 for mobile
00:40:96:b7:ab:5c
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
CCKM: Mobile is using CCKM
!--- The Reassociation Request is received from the client,
which provides the CCKM information needed in order to
derive the new keys with a fast-secure roam.
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
Setting active key cache index 0 ---> 8
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
CCKM: Processing REASSOC REQ IE
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
CCKM: using HMAC MD5 to compute MIC
!--- WLC computes the MIC used for this CCKM fast-roaming
exchange.
*apfMsConnTask_2: Jun 25 15:43:33.750: 00:40:96:b7:ab:5c
CCKM: Received a valid REASSOC REQ IE
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
CCKM: Initializing PMK cache entry with a new PTK
!--- The new PTK is derived.
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 8
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 8
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 0
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Creating a PKC PMKID Cache entry for station
00:40:96:b7:ab:5c (RSN 0) on BSSID 84:78:ac:f0:2a:93
!--- The new PMKID cache entry is created for this new
AP-to-client association.
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
CCKM: using HMAC MD5 to compute MIC
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Including CCKM Response IE (length 62) in Assoc Resp to mobile
*apfMsConnTask_2: Jun 25 15:43:33.751: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:2a:93
(status 0) ApVapId 4 Slot 0
!--- The Reassociation Response is sent from the WLC/AP to
the client, which includes the CCKM information required
in order to confirm the new fast-roam and key derivation.
*dot1xMsgTask: Jun 25 15:43:33.757: 00:40:96:b7:ab:5c
Skipping EAP-Success to mobile 00:40:96:b7:ab:5c
!--- EAP is skipped due to the fast roaming, and CCKM does not
require further key handshakes. The client is now ready to
pass encrypted data frames on the new AP.
Como se muestra, se realiza un roaming de seguridad rápido mientras se evitan las tramas de autenticación EAP y se estrechan aún más las manos, porque las nuevas claves de cifrado aún se derivan, pero se basan en el esquema de negociación CCKM. Esto se completa con las tramas de reasociación de roaming y la información previamente almacenada en caché por el cliente y el WLC.
Pareja piensa que el almacenamiento en caché de Key ID (PMKID), o Sticky Key Caching (SKC), es el primer método de roaming rápido y seguro sugerido por el estándar IEEE 802.11 dentro de la enmienda de seguridad 802.11i, donde el objetivo principal es estandarizar un alto nivel de seguridad para las WLAN. Esta técnica de roaming de seguridad rápida se agregó como un método opcional para los dispositivos WPA2 con el fin de mejorar el roaming cuando se implementó esta seguridad.
Esto es posible porque, cada vez que un cliente está completamente autenticado con EAP, el cliente y el Servidor de autenticación derivan un MSK, que se utiliza para derivar el PMK. Esto se utiliza como la semilla para el protocolo de enlace de 4 vías WPA2 para derivar la clave de cifrado de unidifusión (PTK) final que se utiliza para la sesión (hasta que el cliente se traslada a otro AP o caduca la sesión); por lo tanto, este método evita la fase de autenticación EAP al desplazarse porque reutiliza la PMK original almacenada en caché por el cliente y el AP. El cliente sólo tiene que pasar por el protocolo de enlace de 4 vías WPA2 para obtener nuevas claves de cifrado.
Este método no está ampliamente implementado como el método de roaming de seguridad rápida estándar 802.11 recomendado debido principalmente a estas razones:
Con este método, la asociación inicial a cualquier AP es como una autenticación regular de primera vez a la WLAN, donde la autenticación completa 802.1X/EAP contra el servidor de autenticación y el intercambio de señales de 4 vías para la generación de claves debe ocurrir antes de que el cliente pueda enviar tramas de datos, como se muestra en esta imagen de pantalla:
Las depuraciones revelan el mismo intercambio de tramas de autenticación EAP que el resto de los métodos en la autenticación inicial a la WLAN, con algunas salidas agregadas con respecto a las técnicas de almacenamiento en caché de claves utilizadas aquí. Estos resultados de depuración se cortan para mostrar principalmente la nueva información, no todo el intercambio de tramas EAP, porque básicamente la misma información se intercambia cada vez para la autenticación del cliente contra el servidor de autenticación. Esto se ha demostrado hasta ahora y se correlaciona con las tramas de autenticación EAP que se muestran en las imágenes de paquete, por lo que la mayoría de los mensajes EAP se eliminan de las salidas de depuración por motivos de simplicidad:
*apfMsConnTask_0: Jun 22 00:23:15.097: ec:85:2f:15:39:32
Association received from mobile on BSSID 84:78:ac:f0:68:d2
!--- This is the Association Request from the client.
*apfMsConnTask_0: Jun 22 00:23:15.098: ec:85:2f:15:39:32
Processing RSN IE type 48, length 20 for mobile ec:85:2f:15:39:32
!--- The WLC/AP finds an Information Element that claims PMKID
Caching support on the Association request that is sent
from the client.
*apfMsConnTask_0: Jun 22 00:23:15.098: ec:85:2f:15:39:32
Received RSN IE with 0 PMKIDs from mobile ec:85:2f:15:39:32
!--- Since this is an initial association, the Association
Request comes without any PMKID.
*apfMsConnTask_0: Jun 22 00:23:15.098: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 8
*apfMsConnTask_0: Jun 22 00:23:15.099: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d2
(status 0) ApVapId 3 Slot 0
!--- The Association Response is sent to the client.
*dot1xMsgTask: Jun 22 00:23:15.103: ec:85:2f:15:39:32
Sending EAP-Request/Identity to mobile ec:85:2f:15:39:32
(EAP Id 1)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.118: ec:85:2f:15:39:32
Received EAPOL EAPPKT from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.118: ec:85:2f:15:39:32
Received Identity Response (count=1) from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.126: ec:85:2f:15:39:32
Processing Access-Challenge for mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.126: ec:85:2f:15:39:32
Sending EAP Request from AAA to mobile ec:85:2f:15:39:32
(EAP Id 2)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.146: ec:85:2f:15:39:32
Received EAPOL EAPPKT from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.146: ec:85:2f:15:39:32
Received EAP Response from mobile ec:85:2f:15:39:32
(EAP Id 2, EAP Type 25)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Processing Access-Accept for mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Creating a PKC PMKID Cache entry for station ec:85:2f:15:39:32
(RSN 2)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 8
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 0
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Adding BSSID 84:78:ac:f0:68:d2 to PMKID cache at index 0
for station ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274:
New PMKID: (16)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274:
[0000] c9 4d 0d 97 03 aa a9 0f 1b c8 33 73 01 f1 18 f5
!--- WLC creates a PMK cache entry for this client, which is
used for SKC in this case, so the PMKID is computed with
the AP MAC address (BSSID 84:78:ac:f0:68:d2).
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.274: ec:85:2f:15:39:32
Sending EAP-Success to mobile ec:85:2f:15:39:32
(EAP Id 12)
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.275:
Including PMKID in M1 (16)
!--- The hashed PMKID is included on the Message-1 of the
WPA/WPA2 4-Way handshake.
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.275:
[0000] c9 4d 0d 97 03 aa a9 0f 1b c8 33 73 01 f1 18 f5
!--- This is the hashed PMKID.
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.275: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32
state INITPMK (message 1), replay counter
00.00.00.00.00.00.00.00
!--- Message-1 of the WPA/WPA2 4-Way handshake is sent from
the WLC/AP to the client.
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.284: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.284: ec:85:2f:15:39:32
Received EAPOL-key in PTK_START state (message 2) from mobile
ec:85:2f:15:39:32
!--- Message-2 of the WPA/WPA-2 4-Way handshake is successfully
received from the client.
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.284: ec:85:2f:15:39:32
PMK: Sending cache add
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.285: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32
state PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
!--- Message-3 of the WPA/WPA2 4-Way handshake is sent from
the WLC/AP to the client.
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.291: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:23:15.291: ec:85:2f:15:39:32
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile ec:85:2f:15:39:32
!--- Message-4 (final message) of this initial WPA/WPA2 4-Way
handshake is successfully received from the client, which
confirms the installation of the derived keys. They can
now be used in order to encrypt data frames with the current AP.
Con este método, el AP y el cliente inalámbrico almacenan en caché los PMK de las asociaciones seguras ya establecidas. Por lo tanto, si el cliente inalámbrico se traslada a un nuevo AP donde nunca se ha asociado, el cliente debe realizar una autenticación EAP completa nuevamente, como se muestra en esta imagen donde el cliente se traslada a un nuevo AP:
Sin embargo, si el cliente inalámbrico vuelve a un AP donde se realizó una asociación/autenticación previa, el cliente envía una trama de Solicitud de Reasociación que enumera varios PMKID, que informa al AP de los PMK almacenados en caché de todos los AP donde el cliente se ha autenticado previamente. Por lo tanto, dado que el cliente está regresando a un AP que también tiene un PMK almacenado en caché para este cliente, el cliente no necesita reautenticarse a través de EAP para derivar un nuevo PMK. El cliente simplemente pasa a través del protocolo de enlace WPA2 de 4 vías para derivar las nuevas claves de encriptación transitorias:
Nota: Esta imagen no muestra la primera trama de autenticación de sistema abierto 802.11 del cliente, pero esto no se debe al método implementado, ya que esta trama siempre es necesaria. La razón es que el adaptador o el software de imagen de paquete inalámbrico utilizado para detectar las tramas aéreas de este ejemplo no crea imágenes de esta trama específica, pero se deja así en el ejemplo con fines educativos. Tenga en cuenta que existe la posibilidad de que esto ocurra cuando realice imágenes de paquetes por aire; la imagen puede perder algunas tramas, pero en realidad se intercambian entre el cliente y el AP. De lo contrario, el roaming nunca comienza en este ejemplo.
Aquí está un resumen de las depuraciones del WLC para este método de roaming seguro rápido:
*apfMsConnTask_0: Jun 22 00:26:40.787: ec:85:2f:15:39:32
Reassociation received from mobile on BSSID
84:78:ac:f0:68:d2
!--- This is the Reassociation Request from the client.
*apfMsConnTask_0: Jun 22 00:26:40.787: ec:85:2f:15:39:32
Processing RSN IE type 48, length 38 for mobile
ec:85:2f:15:39:32
!--- The WLC/AP finds an Information Element that claims PMKID
Caching support on the Association request that is sent
from the client.
*apfMsConnTask_0: Jun 22 00:26:40.787: ec:85:2f:15:39:32
Received RSN IE with 1 PMKIDs from mobile
ec:85:2f:15:39:32
!--- The Reassociation Request from the client comes with
one PMKID.
*apfMsConnTask_0: Jun 22 00:26:40.787:
Received PMKID: (16)
*apfMsConnTask_0: Jun 22 00:26:40.788:
[0000] c9 4d 0d 97 03 aa a9 0f 1b c8 33 73 01 f1 18 f5
!--- This is the PMKID that is received.
*apfMsConnTask_0: Jun 22 00:26:40.788: ec:85:2f:15:39:32
Searching for PMKID in MSCB PMKID cache for mobile
ec:85:2f:15:39:32
!--- WLC searches for a matching PMKID on the database.
*apfMsConnTask_0: Jun 22 00:26:40.788: ec:85:2f:15:39:32
Found an cache entry for BSSID 84:78:ac:f0:68:d2 in
PMKID cache at index 0 of station ec:85:2f:15:39:32
*apfMsConnTask_0: Jun 22 00:26:40.788: ec:85:2f:15:39:32
Found a valid PMKID in the MSCB PMKID cache for mobile
ec:85:2f:15:39:32
!--- The WLC validates the PMKID provided by the client,
and confirms that it has a valid PMK cache for this
client-and-AP pair.
*apfMsConnTask_0: Jun 22 00:26:40.788: ec:85:2f:15:39:32
Setting active key cache index 1 ---> 0
*apfMsConnTask_0: Jun 22 00:26:40.788: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID
84:78:ac:f0:68:d2(status 0) ApVapId 3 Slot 0
!--- The Reassociation Response is sent to the client, which
validates the fast-roam with SKC.
*dot1xMsgTask: Jun 22 00:26:40.795: ec:85:2f:15:39:32
Initiating RSN with existing PMK to mobile
ec:85:2f:15:39:32
!--- WLC initiates a Robust Secure Network association with
this client-and-AP pair based on the cached PMK found.
Hence, EAP is avoided as per the next message.
*dot1xMsgTask: Jun 22 00:26:40.795: ec:85:2f:15:39:32
Skipping EAP-Success to mobile ec:85:2f:15:39:32
*dot1xMsgTask: Jun 22 00:26:40.795: ec:85:2f:15:39:32
Found an cache entry for BSSID 84:78:ac:f0:68:d2 in
PMKID cache at index 0 of station ec:85:2f:15:39:32
*dot1xMsgTask: Jun 22 00:26:40.795: Including PMKID in M1(16)
!--- The hashed PMKID is included on the Message-1 of the
WPA/WPA2 4-Way handshake.
*dot1xMsgTask: Jun 22 00:26:40.795:
[0000] c9 4d 0d 97 03 aa a9 0f 1b c8 33 73 01 f1 18 f5
!--- The PMKID is hashed. The next messages are the same
WPA/WPA2 4-Way handshake messages described thus far
that are used in order to finish the encryption keys
generation/installation.
*dot1xMsgTask: Jun 22 00:26:40.795: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32 state
INITPMK (message 1), replay counter 00.00.00.00.00.00.00.00
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.811: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.812: ec:85:2f:15:39:32
Received EAPOL-key in PTK_START state (message 2) from mobile
ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.812: ec:85:2f:15:39:32
PMK: Sending cache add
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.812: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32 state
PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.820: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 22 00:26:40.820: ec:85:2f:15:39:32
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile ec:85:2f:15:39:32
Este método se puede implementar localmente mediante AP autónomos independientes, sin la necesidad de un dispositivo centralizado para administrar las claves almacenadas en caché.
El almacenamiento en caché de claves oportunista (OKC), también conocido como almacenamiento en caché de claves proactivo (PKC) (este término se explica con más detalle en una nota que sigue), es básicamente una mejora del método de almacenamiento en caché PMKID WPA2 descrito anteriormente, por lo que también se denomina almacenamiento en caché PMKID proactivo/oportunista. Por lo tanto, es importante tener en cuenta que este no es un método de roaming de seguridad rápida definido por el estándar 802.11 y no es compatible con muchos dispositivos, pero al igual que el almacenamiento en caché PMKID, funciona con WPA2-EAP.
Esta técnica permite que el cliente inalámbrico y la infraestructura WLAN almacenen en caché sólo un PMK durante la duración de la asociación del cliente con esta WLAN (derivada de la MSK después de la autenticación 802.1X/EAP inicial con el servidor de autenticación), incluso cuando se desplaza entre varios AP, ya que todos comparten el PMK original que se utiliza como la semilla en todos los handshakes de 4 direcciones WPA2. Esto sigue siendo necesario, al igual que en SKC, para generar nuevas claves de cifrado cada vez que el cliente se reasocia con los AP. Para que los AP compartan esta única PMK original de la sesión del cliente, todos deben estar bajo algún tipo de control administrativo, con un dispositivo centralizado que almacene en caché y distribuya la PMK original para todos los AP. Esto es similar al CUWN, donde el WLC realiza este trabajo para todos los LAPs bajo su control, y utiliza los grupos de movilidad para manejar este PMK entre los WLCs múltiples; por lo tanto, esto es una limitación en los entornos AP autónomos.
Con este método, al igual que en el almacenamiento en caché de PMKID (SKC), la asociación inicial a cualquier AP es una autenticación regular por primera vez a la WLAN, donde debe completar toda la autenticación 802.1X/EAP contra el servidor de autenticación y el protocolo de enlace de 4 vías para la generación de claves antes de poder enviar tramas de datos. Esta es una imagen de pantalla que ilustra esto:
Las salidas de debug muestran básicamente el mismo intercambio de tramas de autenticación EAP que el resto de los métodos descritos en este documento sobre la autenticación inicial a la WLAN (como se muestra en las imágenes), junto con la adición de algunas salidas que se refieren a las técnicas de almacenamiento en caché de claves utilizadas por el WLC aquí. Este resultado de depuración también se corta para mostrar solamente la información relevante:
*apfMsConnTask_0: Jun 21 21:46:06.515: 00:40:96:b7:ab:5c
Association received from mobile on BSSID
84:78:ac:f0:68:d2
!--- This is the Association Request from the client.
*apfMsConnTask_0: Jun 21 21:46:06.516: 00:40:96:b7:ab:5c
Processing RSN IE type 48, length 20 for mobile
00:40:96:b7:ab:5c
!--- The WLC/AP finds an Information Element that claims
PMKID Caching support on the Association request that
is sent from the client.
*apfMsConnTask_0: Jun 21 21:46:06.516: 00:40:96:b7:ab:5c
Received RSN IE with 0 PMKIDs from mobile
00:40:96:b7:ab:5c
!--- Since this is an initial association, the Association
Request comes without any PMKID.
*apfMsConnTask_0: Jun 21 21:46:06.516: 00:40:96:b7:ab:5c
Setting active key cache index 0 ---> 8
*apfMsConnTask_0: Jun 21 21:46:06.516: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID
84:78:ac:f0:68:d2 (status 0) ApVapId 3 Slot
!--- The Association Response is sent to the client.
*dot1xMsgTask: Jun 21 21:46:06.522: 00:40:96:b7:ab:5
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 1)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.614: 00:40:96:b7:ab:5c
Received EAPOL START from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.614: 00:40:96:b7:ab:5c
Sending EAP-Request/Identity to mobile 00:40:96:b7:ab:5c
(EAP Id 2)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.623: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.623: 00:40:96:b7:ab:5c
Received Identity Response (count=2) from mobile
00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.630: 00:40:96:b7:ab:5c
Processing Access-Challenge for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.630: 00:40:96:b7:ab:5c
Sending EAP Request from AAA to mobile 00:40:96:b7:ab:5c
(EAP Id 3)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.673: 00:40:96:b7:ab:5c
Received EAPOL EAPPKT from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.673: 00:40:96:b7:ab:5c
Received EAP Response from mobile 00:40:96:b7:ab:5c
(EAP Id 3, EAP Type 25)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.843: 00:40:96:b7:ab:5c
Processing Access-Accept for mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Creating a PKC PMKID Cache entry for station
00:40:96:b7:ab:5c (RSN 2)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 8
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Setting active key cache index 8 ---> 0
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Adding BSSID 84:78:ac:f0:68:d2 to PMKID cache at index 0
for station 00:40:96:b7:ab:5
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: New PMKID: (16)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844:
[0000] 4e a1 7f 5a 75 48 9c f9 96 e3 a8 71 25 6f 11 d0
!--- WLC creates a PMK cache entry for this client, which is
used for OKC in this case, so the PMKID is computed
with the AP MAC address (BSSID 84:78:ac:f0:68:d2).
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
PMK sent to mobility group
!--- The PMK cache entry for this client is shared with the
WLCs on the mobility group.
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Sending EAP-Success to mobile 00:40:96:b7:ab:5c (EAP Id 13)
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Found an cache entry for BSSID 84:78:ac:f0:68:d2 in PMKID
cache at index 0 of station 00:40:96:b7:ab:5
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: Including PMKID
in M1 (16)
!--- The hashed PMKID is included on the Message-1 of the
WPA/WPA2 4-Way handshake.
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844:
[0000] 4e a1 7f 5a 75 48 9c f9 96 e3 a8 71 25 6f 11 d0
!--- This is the hashed PMKID. The next messages are the same
WPA/WPA2 4-Way handshake messages described thus far that
are used in order to finish the encryption keys
generation/installation.
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.844: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c state
INITPMK (message 1), replay counter 00.00.00.00.00.00.00.00
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.865: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.865: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2)
from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.865: 00:40:96:b7:ab:5c
PMK: Sending cache add
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.865: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c state
PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.889: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:46:06.890: 00:40:96:b7:ab:5c
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile 00:40:96:b7:ab:5c
Con este método, el cliente inalámbrico y el WLC (para todos los AP administrados) almacenan en caché el único PMK original de la asociación segura que se establece inicialmente. Básicamente, cada vez que el cliente inalámbrico se conecta a un AP específico, un PMKID se trocea en función de: la dirección MAC del cliente, la dirección MAC del AP (BSSID del WLAN), y el PMK derivado con ese AP. Por lo tanto, dado que OKC almacena en caché el mismo PMK original para todos los AP y el cliente específico, cuando este cliente (re)asocia a otro AP, el único valor que cambia para hacer hash con el nuevo PMKID es la nueva dirección MAC del AP.
Cuando el cliente inicia el roaming a un nuevo AP y envía la trama de Solicitud de reasociación, agrega el PMKID en el elemento de información RSN WPA2 si desea informar al AP que un PMK almacenado en caché se utiliza para el roaming seguro rápido. Ya conoce la dirección MAC del BSSID (AP) por donde se traslada, entonces el cliente simplemente hace un hashes con el nuevo PMKID que se utiliza en esta Solicitud de Reasociación. Cuando el AP recibe esta solicitud del cliente, también hace un hashes del PMKID con los valores que ya tiene (el PMK almacenado en caché, la dirección MAC del cliente y su propia dirección MAC del AP), y responde con la respuesta de reasociación exitosa que confirma que los PMKIDs coinciden. El PMK almacenado en caché se puede utilizar como la semilla que inicia un protocolo de enlace de 4 vías WPA2 para derivar las nuevas claves de cifrado (y omitir EAP):
En esta imagen, se selecciona y expande el marco de solicitud de reasociación del cliente para que pueda ver más detalles del marco. La información de la dirección MAC y también el elemento de información Red de seguridad sólida (RSN, según 802.11i - WPA2), donde se muestra información sobre la configuración de WPA2 utilizada para esta asociación (resaltado es el PMKID obtenido de la fórmula con hash).
Aquí está un resumen de los debugs del WLC para este método de roaming seguro rápido con OKC:
*apfMsConnTask_2: Jun 21 21:48:50.562: 00:40:96:b7:ab:5c
Reassociation received from mobile on BSSID
84:78:ac:f0:2a:92
!--- This is the Reassociation Request from the client.
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Processing RSN IE type 48, length 38 for mobile
00:40:96:b7:ab:5c
!--- The WLC/AP finds and Information Element that claims
PMKID Caching support on the Association request that
is sent from the client.
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Received RSN IE with 1 PMKIDs from mobile
00:40:96:b7:ab:5c
!--- The Reassociation Request from the client comes with
one PMKID.
*apfMsConnTask_2: Jun 21 21:48:50.563:
Received PMKID: (16)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 91 65 c3 fb fc 44 75 48 67 90 d5 da df aa 71 e9
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Searching for PMKID in MSCB PMKID cache for mobile
00:40:96:b7:ab:5c
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
No valid PMKID found in the MSCB PMKID cache for mobile
00:40:96:b7:ab:5
!--- As the client has never authenticated with this new AP,
the WLC cannot find a valid PMKID to match the one provided
by the client. However, since the client performs OKC
and not SKC (as per the following messages), the WLC computes
a new PMKID based on the information gathered (the cached PMK,
the client MAC address, and the new AP MAC address).
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Trying to compute a PMKID from MSCB PMK cache for mobile
00:40:96:b7:ab:5c
*apfMsConnTask_2: Jun 21 21:48:50.563:
CCKM: Find PMK in cache: BSSID = (6)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 84 78 ac f0 2a 90
*apfMsConnTask_2: Jun 21 21:48:50.563:
CCKM: Find PMK in cache: realAA = (6)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 84 78 ac f0 2a 92
*apfMsConnTask_2: Jun 21 21:48:50.563:
CCKM: Find PMK in cache: PMKID = (16)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 91 65 c3 fb fc 44 75 48 67 90 d5 da df aa 71 e9
*apfMsConnTask_2: Jun 21 21:48:50.563:
CCKM: AA (6)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 84 78 ac f0 2a 92
*apfMsConnTask_2: Jun 21 21:48:50.563:
CCKM: SPA (6)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 00 40 96 b7 ab 5c
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Adding BSSID 84:78:ac:f0:2a:92 to PMKID cache at
index 0 for station 00:40:96:b7:ab:5c
*apfMsConnTask_2: Jun 21 21:48:50.563:
New PMKID: (16)
*apfMsConnTask_2: Jun 21 21:48:50.563:
[0000] 91 65 c3 fb fc 44 75 48 67 90 d5 da df aa 71 e9
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Computed a valid PMKID from MSCB PMK cache for mobile
00:40:96:b7:ab:5c
!--- The new PMKID is computed and validated to match the
one provided by the client, which is also computed with
the same information. Hence, the fast-secure roam is
possible.
*apfMsConnTask_2: Jun 21 21:48:50.563: 00:40:96:b7:ab:5c
Setting active key cache index 0 ---> 0
*apfMsConnTask_2: Jun 21 21:48:50.564: 00:40:96:b7:ab:5c
Sending Assoc Response to station on BSSID 84:78:ac:f0:2a:92
(status 0) ApVapId 3 Slot
!--- The Reassociation response is sent to the client, which
validates the fast-roam with OKC.
*dot1xMsgTask: Jun 21 21:48:50.570: 00:40:96:b7:ab:5c
Initiating RSN with existing PMK to mobile
00:40:96:b7:ab:5c
!--- WLC initiates a Robust Secure Network association with
this client-and AP pair with the cached PMK found.
Hence, EAP is avoided, as per the the next message.
*dot1xMsgTask: Jun 21 21:48:50.570: 00:40:96:b7:ab:5c
Skipping EAP-Success to mobile 00:40:96:b7:ab:5c
*dot1xMsgTask: Jun 21 21:48:50.570: 00:40:96:b7:ab:5c
Found an cache entry for BSSID 84:78:ac:f0:2a:92 in
PMKID cache at index 0 of station 00:40:96:b7:ab:5c
*dot1xMsgTask: Jun 21 21:48:50.570:
Including PMKID in M1 (16)
!--- The hashed PMKID is included on the Message-1 of the
WPA/WPA2 4-Way handshake.
*dot1xMsgTask: Jun 21 21:48:50.570:
[0000] 91 65 c3 fb fc 44 75 48 67 90 d5 da df aa 71 e9
!--- The PMKID is hashed. The next messages are the same
WPA/WPA2 4-Way handshake messages described thus far,
which are used in order to finish the encryption keys
generation/installation.
*dot1xMsgTask: Jun 21 21:48:50.570: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c state
INITPMK (message 1), replay counter 00.00.00.00.00.00.00.00
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.589: 00:40:96:b7:ab:5
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.589: 00:40:96:b7:ab:5c
Received EAPOL-key in PTK_START state (message 2) from mobile
00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.589: 00:40:96:b7:ab:5c
PMK: Sending cache add
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.590: 00:40:96:b7:ab:5c
Sending EAPOL-Key Message to mobile 00:40:96:b7:ab:5c state
PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.610: 00:40:96:b7:ab:5c
Received EAPOL-Key from mobile 00:40:96:b7:ab:5c
*Dot1x_NW_MsgTask_4: Jun 21 21:48:50.610: 00:40:96:b7:ab:5c
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile 00:40:96:b7:ab:5c
Como se muestra al principio de las depuraciones, el PMKID debe calcularse después de que se reciba la solicitud de reasociación del cliente. Esto es necesario para validar el PMKID y confirmar que el PMK almacenado en caché se utiliza con el protocolo de enlace de 4 vías WPA2 para derivar las claves de cifrado y finalizar el roaming de seguridad rápida. No confunda las entradas de CCKM en los debugs; esto no se utiliza para realizar CCKM, sino OKC, como se explicó anteriormente. CCKM aquí es simplemente un nombre utilizado por el WLC para esas salidas, como el nombre de una función que maneja los valores para calcular el PMKID.
Nota: Esta configuración puede funcionar si los AP no están en el mismo grupo FlexConnect, pero no es una configuración recomendada o admitida.
El almacenamiento en caché de claves proactivo (o PKC) se conoce como OKC (Opportunistic Key Caching), y los dos términos se utilizan indistintamente cuando describen el mismo método aquí explicado. Sin embargo, este era solo un término que Airspace utilizó en 2001 para un antiguo método de almacenamiento en caché de claves, que luego fue utilizado por el estándar 802.11i como base para la "Preautenticación" (otro método de roaming seguro rápido explicado brevemente a continuación). PKC no es Preauthentication ni OKC (Opportunistic Key Caching), pero cuando usted escucha o lee acerca de PKC, la referencia es básicamente a OKC, y no a Preauthentication.
Este método también lo sugiere el estándar IEEE 802.11 en la enmienda de seguridad 802.11i, por lo que también funciona con WPA2, pero es el único método de roaming seguro rápido que no es compatible con la infraestructura WLAN de Cisco. Por esta razón, se explica brevemente aquí y sin resultados.
Con la autenticación previa, los clientes inalámbricos pueden autenticarse con varios AP a la vez mientras están asociados con el AP actual. Cuando esto ocurre, el cliente envía las tramas de autenticación EAP al AP actual donde está conectado, pero está destinado a los otros AP donde el cliente quiere realizar la autenticación previa (AP vecinos que son posibles candidatos para el roaming). El AP actual envía estas tramas a los AP de destino a través del sistema de distribución. El nuevo AP realiza una autenticación completa contra el servidor RADIUS para este cliente, por lo que se completa un nuevo protocolo de enlace de autenticación EAP, y este nuevo AP actúa como el autenticador.
La idea es realizar la autenticación y derivar el PMK con los AP vecinos antes de que el cliente realmente se traslade a ellos, por lo que cuando es el momento de trasladarse, el cliente ya está autenticado y con un PMK ya almacenado en caché para esta nueva asociación segura de AP a cliente, por lo que solo necesitan realizar el intercambio de señales de 4 vías y experimentar una itinerancia rápida después de que el cliente envíe su solicitud de reasociación inicial.
Esta es una imagen de una baliza AP que muestra el campo RSN IE que anuncia el soporte para la autenticación previa (esta es de un Cisco AP, donde se confirma que la autenticación previa no es compatible):
Hay un PMK para cada asociación segura de AP a cliente, que podría considerarse una ventaja de seguridad en caso de que un AP se vea comprometido y las claves sean robadas (no se pueden utilizar con otros AP). Sin embargo, esta ventaja de seguridad es manejada por la infraestructura WLAN de diferentes maneras en otros métodos.
La técnica de roaming de seguridad rápida basada en la enmienda 802.11r (oficialmente denominada Transición rápida de BSS por el estándar 802.11 y conocida como FT) es el primer método ratificado oficialmente (en 2008) por el IEEE para el estándar 802.11 como la solución para realizar transiciones rápidas entre los AP (conjuntos de servicios básicos o BSS), que define claramente la jerarquía de claves que se utiliza cuando se manejan y almacenan en caché claves en una WLAN. Sin embargo, su adopción ha sido lenta, principalmente debido a las otras soluciones ya disponibles cuando se requerían transiciones rápidas, como con las implementaciones de VoWLAN cuando se utiliza con uno de los métodos previamente explicados en este documento. Solo hay unos pocos dispositivos que actualmente admitan algunas de las opciones de FT (en 2013).
Esta técnica es más compleja de explicar que los otros métodos, ya que introduce nuevos conceptos y varias capas de PMK que se almacenan en caché en diferentes dispositivos (cada dispositivo tiene una función diferente) y proporciona incluso más opciones para la itinerancia segura y rápida. Por lo tanto, se proporciona un breve resumen sobre este método y la forma en que se implementa con cada opción disponible.
802.11r es diferente de SKC y OKC, principalmente debido a estas razones:
Con este método, el cliente inalámbrico realiza solamente una autenticación inicial contra la infraestructura WLAN cuando se establece una conexión con el primer AP, y realiza un roaming seguro rápido mientras se desplaza entre los AP del mismo dominio de movilidad FT.
Este es uno de los nuevos conceptos, que básicamente se refiere a los AP que utilizan el mismo SSID (conocido como conjunto de servicios extendido o ESS) y manejan las mismas claves FT. Esto es similar a los otros métodos explicados hasta ahora. La forma en que los AP manejan las claves de dominio de movilidad de FT se basa normalmente en una configuración centralizada, como el WLC o los grupos de movilidad; sin embargo, este método también se puede implementar en entornos AP autónomos.
A continuación se muestra un resumen de la jerarquía de claves:
Nota: En función del proveedor de WLAN y de las configuraciones de implementación (como los puntos de acceso autónomos, FlexConnect o Mesh), la infraestructura WLAN puede transferir y gestionar las claves de una forma diferente. Incluso puede cambiar las funciones de los titulares de las claves, pero como eso está fuera del alcance de este documento, los ejemplos basados en el resumen de jerarquía de claves que se dio anteriormente son el siguiente enfoque. En realidad, las diferencias no son tan relevantes para comprender el proceso, a menos que realmente necesite analizar en profundidad los dispositivos de infraestructura (y su código) para descubrir un problema de software.
Con este método, la primera asociación a cualquier AP es una autenticación regular por primera vez a la WLAN, donde la autenticación completa 802.1X/EAP contra el servidor de autenticación y el intercambio de señales de 4 vías para la generación de claves debe ocurrir antes de que se envíen las tramas de datos, como se muestra en esta imagen de pantalla:
Las principales diferencias son:
Las depuraciones muestran básicamente el mismo intercambio de tramas de autenticación EAP que el resto de los métodos en la autenticación inicial a la WLAN (como se observa en las imágenes), pero se agregan algunas salidas que se refieren a las técnicas de almacenamiento en caché de claves utilizadas por el WLC; por lo tanto, esta salida de depuración se corta para mostrar solamente la información relevante:
*apfMsConnTask_0: Jun 27 19:25:23.426: ec:85:2f:15:39:32
Association received from mobile on BSSID
84:78:ac:f0:68:d6
!--- This is the Association request from the client.
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Marking this mobile as TGr capable.
!--- WLC recognizes that the client is 802.11r-capable.
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Processing RSN IE type 48, length 20 for mobile
ec:85:2f:15:39:32
!--- The WLC/AP finds an Information Element that claims FT
support on the Association request that is sent from the client.
*apfMsConnTask_0: Jun 27 19:25:23.427:
Sending assoc-resp station:ec:85:2f:15:39:32
AP:84:78:ac:f0:68:d0-00 thread:144be808
*apfMsConnTask_0: Jun 27 19:25:23.427:
Adding MDIE, ID is:0xaaf0
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Including FT Mobility Domain IE (length 5) in Initial
assoc Resp to mobile
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Sending R0KH-ID as:-84.30.6.-3
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Sending R1KH-ID as 3c:ce:73:d8:02:00
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Including FT IE (length 98) in Initial Assoc Resp to mobile
*apfMsConnTask_0: Jun 27 19:25:23.427: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d6
(status 0) ApVapId 7 Slot 0
!--- The Association Response is sent to the client once the
FT information is computed (as per the previous messages),
so this is included in the response.
*dot1xMsgTask: Jun 27 19:25:23.432: ec:85:2f:15:39:32
Sending EAP-Request/Identity to mobile ec:85:2f:15:39:32
(EAP Id 1)
!--- EAP begins, andfollows
the same exchange explained so far.
*apfMsConnTask_0: Jun 27 19:25:23.436: ec:85:2f:15:39:32
Got action frame from this client.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.449: ec:85:2f:15:39:32
Received EAPOL EAPPKT from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.449: ec:85:2f:15:39:32
Received Identity Response (count=1) from mobile
ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.456: ec:85:2f:15:39:32
Processing Access-Challenge for mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.456: ec:85:2f:15:39:32
Sending EAP Request from AAA to mobile ec:85:2f:15:39:32
(EAP Id 2)
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.479: ec:85:2f:15:39:32
Received EAPOL EAPPKT from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.479: ec:85:2f:15:39:32
Received EAP Response from mobile ec:85:2f:15:39:32
(EAP Id 2, EAP Type 25)
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.627: ec:85:2f:15:39:32
Processing Access-Accept for mobile ec:85:2f:15:39:32
!--- The client is validated/authenticated by the RADIUS Server.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.627: ec:85:2f:15:39:32
Creating a PKC PMKID Cache entry for station
ec:85:2f:15:39:32 (RSN 2)
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.627: ec:85:2f:15:39:32
Resetting MSCB PMK Cache Entry 0 for station
ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.627: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 8
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.628: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 0
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.628: ec:85:2f:15:39:32
Adding BSSID 84:78:ac:f0:68:d6 to PMKID cache at index 0
for station ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.628: New PMKID: (16)
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.628:
[0000] 52 b8 8f cf 50 a7 90 98 2b ba d6 20 79 e4 cd f9
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.629: ec:85:2f:15:39:32
Created PMK Cache Entry for TGr AKM:802.1x ec:85:2f:15:39:32
!--- WLC creates a PMK cache entry for this client, which is
used for FT with 802.1X in this case, so the PMKID is
computed with the AP MAC address (BSSID 84:78:ac:f0:68:d6).
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.629:
ec:85:2f:15:39:32 R0KH-ID:172.30.6.253
R1KH-ID:3c:ce:73:d8:02:00 MSK Len:48 pmkValidTime:1807
!--- The R0KH-ID and R1KH-ID are defined, as well as the PMK
cache validity period.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630: ec:85:2f:15:39:32
PMK sent to mobility group
!--- The FT PMK cache entry for this client is shared with the
WLCs on the mobility group.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630: ec:85:2f:15:39:32
Sending EAP-Success to mobile ec:85:2f:15:39:32 (EAP Id 12)
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630: ec:85:2f:15:39:32
Found an cache entry for BSSID 84:78:ac:f0:68:d6 in PMKID
cache at index 0 of station ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630: Including PMKID in
M1 (16)
!--- The hashed PMKID is included on the Message-1 of the
initial FT 4-Way handshake.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630:
[0000] 52 b8 8f cf 50 a7 90 98 2b ba d6 20 79 e4 cd f9
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.630: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32 state
INITPMK (message 1), replay counter 00.00.00.00.00.00.00.0
!--- Message-1 of the FT 4-Way handshake is sent from the
WLC/AP to the client.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
Received EAPOL-key in PTK_START state (message 2) from
mobile ec:85:2f:15:39:32
!--- Message-2 of the FT 4-Way handshake is received
successfully from the client.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
Calculating PMKR0Name
!--- The PMKR0Name is calculated.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
DOT11R: Sending cache add
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: Adding MDIE,
ID is:0xaaf0
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
Adding TIE for reassociation deadtime:20000 milliseconds
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.639: ec:85:2f:15:39:32
Adding TIE for R0Key-Data valid time :1807
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.640: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32 state
PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
!--- After the MDIE, TIE for reassociation deadtime, and TIE
for R0Key-Data valid time are calculated, the Message-3
of this FT 4-Way handshake is sent from the WLC/AP to the
client with this information.
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.651: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:25:23.651: ec:85:2f:15:39:32
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile ec:85:2f:15:39:32
!--- Message-4 (final message) of this initial FT 4-Way handshake
is received successfully from the client, which confirms the
installation of the derived keys. They can now be used in order
to encrypt data frames with the current AP.
Nota: Para depurar este método y alcanzar los resultados adicionales de 802.11r/FT que se muestran aquí, se habilita una depuración adicional junto con el cliente de depuración, que es debug ft events enable.
Estas son las imágenes y depuraciones de una asociación inicial a la WLAN cuando se realiza FT con WPA2-PSK (en lugar de un método 802.1X/EAP), donde se selecciona la trama de respuesta de asociación del AP para mostrar el elemento de información de transición rápida de BSS (resaltado). También se muestra parte de la información clave necesaria para realizar el protocolo de enlace FT de 4 vías:
*apfMsConnTask_0: Jun 27 19:29:09.136: ec:85:2f:15:39:32
Association received from mobile on BSSID
84:78:ac:f0:68:d4
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Marking this mobile as TGr capable.
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Processing RSN IE type 48, length 20 for mobile
ec:85:2f:15:39:32
*apfMsConnTask_0: Jun 27 19:29:09.137: Sending assoc-resp
station:ec:85:2f:15:39:32 AP:84:78:ac:f0:68:d0-00
thread:144be808
*apfMsConnTask_0: Jun 27 19:29:09.137: Adding MDIE,
ID is:0xaaf0
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Including FT Mobility Domain IE (length 5) in Initial
assoc Resp to mobile
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Sending R0KH-ID as:-84.30.6.-3
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Sending R1KH-ID as 3c:ce:73:d8:02:00
*apfMsConnTask_0: Jun 27 19:29:09.137: ec:85:2f:15:39:32
Including FT IE (length 98) in Initial Assoc Resp to mobile
*apfMsConnTask_0: Jun 27 19:29:09.138: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID 84:78:ac:f0:68:d4
(status 0) ApVapId 5 Slot 0
*dot1xMsgTask: Jun 27 19:29:09.141: ec:85:2f:15:39:32
Creating a PKC PMKID Cache entry for station
ec:85:2f:15:39:32 (RSN 2)
*dot1xMsgTask: Jun 27 19:29:09.141: ec:85:2f:15:39:32
Resetting MSCB PMK Cache Entry 0 for station
ec:85:2f:15:39:32
*dot1xMsgTask: Jun 27 19:29:09.141: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 8
*dot1xMsgTask: Jun 27 19:29:09.141: ec:85:2f:15:39:32
Setting active key cache index 8 ---> 0
*dot1xMsgTask: Jun 27 19:29:09.141: ec:85:2f:15:39:32
Adding BSSID 84:78:ac:f0:68:d4 to PMKID cache at
index 0 for station ec:85:2f:15:39:32
*dot1xMsgTask: Jun 27 19:29:09.142: New PMKID: (16)
*dot1xMsgTask: Jun 27 19:29:09.142:
[0000] 17 4b 17 5c ed 5f c7 1d 66 39 e9 5d 3a 63 69 e7
*dot1xMsgTask: Jun 27 19:29:09.142: ec:85:2f:15:39:32
Creating global PMK cache for this TGr client
*dot1xMsgTask: Jun 27 19:29:09.142: ec:85:2f:15:39:32
Created PMK Cache Entry for TGr AKM:PSK
ec:85:2f:15:39:32
*dot1xMsgTask: Jun 27 19:29:09.142: ec:85:2f:15:39:32
R0KH-ID:172.30.6.253 R1KH-ID:3c:ce:73:d8:02:00
MSK Len:48 pmkValidTime:1813
*dot1xMsgTask: Jun 27 19:29:09.142: ec:85:2f:15:39:32
Initiating RSN PSK to mobile ec:85:2f:15:39:32
*dot1xMsgTask: Jun 27 19:29:09.142: ec:85:2f:15:39:32
Found an cache entry for BSSID 84:78:ac:f0:68:d4 in
PMKID cache at index 0 of station ec:85:2f:15:39:32
*dot1xMsgTask: Jun 27 19:29:09.142: Including PMKID
in M1 (16)
*dot1xMsgTask: Jun 27 19:29:09.142:
[0000] 17 4b 17 5c ed 5f c7 1d 66 39 e9 5d 3a 63 69 e7
*dot1xMsgTask: Jun 27 19:29:09.143: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32
state INITPMK (message 1), replay counter
00.00.00.00.00.00.00.00
*apfMsConnTask_0: Jun 27 19:29:09.144: ec:85:2f:15:39:32
Got action frame from this client.
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.152: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.153: ec:85:2f:15:39:32
Received EAPOL-key in PTK_START state (message 2) from
mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.153: ec:85:2f:15:39:32
Calculating PMKR0Name
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.153: Adding MDIE,
ID is:0xaaf0
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.153: ec:85:2f:15:39:32
Adding TIE for reassociation deadtime:20000 milliseconds
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.153: ec:85:2f:15:39:32
Adding TIE for R0Key-Data valid time :1813
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.154: ec:85:2f:15:39:32
Sending EAPOL-Key Message to mobile ec:85:2f:15:39:32 state
PTKINITNEGOTIATING (message 3), replay counter
00.00.00.00.00.00.00.01
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.163: ec:85:2f:15:39:32
Received EAPOL-Key from mobile ec:85:2f:15:39:32
*Dot1x_NW_MsgTask_2: Jun 27 19:29:09.163: ec:85:2f:15:39:32
Received EAPOL-key in PTKINITNEGOTIATING state (message 4)
from mobile ec:85:2f:15:39:32
Con 802.11r, la asociación inicial a la WLAN es la base utilizada para derivar las claves base utilizadas por esta técnica, al igual que en los otros métodos de roaming de seguridad rápida. Las principales diferencias se producen cuando el cliente comienza a vagar; FT no solo evita 802.1X/EAP cuando se utiliza, sino que en realidad realiza un método de roaming más eficiente que combina las tramas iniciales de autenticación y reasociación de sistema abierto 802.11 (que siempre se utilizan y requieren cuando se roaming entre AP) para intercambiar información FT y derivar nuevas claves de cifrado dinámico en lugar del protocolo de enlace de 4 vías.
La siguiente imagen muestra las tramas intercambiadas cuando se realiza una transición rápida de BSS en el aire con seguridad 802.1X/EAP. Se selecciona la trama de autenticación de sistema abierto desde el cliente al AP para ver los elementos de información del protocolo FT que se requieren para comenzar la negociación de la clave FT. Esto se utiliza para derivar la nueva PTK con el nuevo AP (basado en el PMK-R1). El campo que muestra el algoritmo de autenticación se resalta para mostrar que este cliente no realiza una simple autenticación de sistema abierto, sino una transición rápida de BSS:
Éstos son los resultados de debug del WLC cuando este evento de roaming de FT ocurre con 802.1X/EAP:
*apfMsConnTask_2: Jun 27 19:25:48.751: ec:85:2f:15:39:32
Doing preauth for this client over the Air
!--- WLC begins FT fast-secure roaming over-the-Air with
this client and performs a type of preauthentication,
because the client asks for this with FT on the Authentication
frame that is sent to the new AP over-the-Air
(before the Reassociation Request).
*apfMsConnTask_2: Jun 27 19:25:48.751: ec:85:2f:15:39:32
Doing local roaming for destination address
84:78:ac:f0:2a:96
!--- WLC performs the local roaming event with the new AP to
which the client roams.
*apfMsConnTask_2: Jun 27 19:25:48.751: ec:85:2f:15:39:32
Got 1 AKMs in RSNIE
*apfMsConnTask_2: Jun 27 19:25:48.751: ec:85:2f:15:39:32
RSNIE AKM matches with PMK cache entry :0x3
!--- WLC receives one PMK from this client (known as AKM here),
which matches the PMK cache entry hold for this client.
*apfMsConnTask_2: Jun 27 19:25:48.751: ec:85:2f:15:39:32
Created a new preauth entry for AP:84:78:ac:f0:2a:96
*apfMsConnTask_2: Jun 27 19:25:48.751: Adding MDIE,
ID is:0xaaf0
!--- WLC creates a new preauth entry for this AP-and-Client pair,
and adds the MDIE information.
*apfMsConnTask_2: Jun 27 19:25:48.763: Processing assoc-req
station:ec:85:2f:15:39:32 AP:84:78:ac:f0:2a:90-00
thread:144bef38
*apfMsConnTask_2: Jun 27 19:25:48.763: ec:85:2f:15:39:32
Reassociation received from mobile on BSSID
84:78:ac:f0:2a:96
!--- Once the client receives the Authentication frame reply from the
WLC/AP, the Reassociation request is sent, which is received at
the new AP to which the client roams.
*apfMsConnTask_2: Jun 27 19:25:48.764: ec:85:2f:15:39:32
Marking this mobile as TGr capable.
*apfMsConnTask_2: Jun 27 19:25:48.764: ec:85:2f:15:39:32
Processing RSN IE type 48, length 38 for mobile
ec:85:2f:15:39:32
*apfMsConnTask_2: Jun 27 19:25:48.765: ec:85:2f:15:39:32
Roaming succeed for this client.
!--- WLC confirms that the FT fast-secure roaming is successful
for this client.
*apfMsConnTask_2: Jun 27 19:25:48.765: Sending assoc-resp
station:ec:85:2f:15:39:32 AP:84:78:ac:f0:2a:90-00
thread:144bef38
*apfMsConnTask_2: Jun 27 19:25:48.766: Adding MDIE,
ID is:0xaaf0
*apfMsConnTask_2: Jun 27 19:25:48.766: ec:85:2f:15:39:32
Including FT Mobility Domain IE (length 5) in
reassociation assoc Resp to mobile
*apfMsConnTask_2: Jun 27 19:25:48.766: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID 84:78:ac:f0:2a:96
(status 0) ApVapId 7 Slot 0
!--- The Reassociation response is sent to the client, which
includes the FT Mobility Domain IE.
*dot1xMsgTask: Jun 27 19:25:48.769: ec:85:2f:15:39:32
Finishing FT roaming for mobile ec:85:2f:15:39:32
!--- FT roaming finishes and EAP is skipped (as well as any
other key management handshake), so the client is ready
to pass encrypted data frames with the current AP.
*dot1xMsgTask: Jun 27 19:25:48.769: ec:85:2f:15:39:32
Skipping EAP-Success to mobile ec:85:2f:15:39:32
Esta es una imagen que muestra una transición rápida de BSS en el aire con seguridad WPA2-PSK, donde se selecciona la trama de respuesta de reasociación final del AP al cliente para mostrar más detalles sobre este intercambio de FT:
Estas son las salidas de depuración cuando este evento de roaming de FT ocurre con PSK, que son similares a las que se utilizan cuando se utiliza 802.1X/EAP:
*apfMsConnTask_2: Jun 27 19:29:29.854: ec:85:2f:15:39:32
Doing preauth for this client over the Air
*apfMsConnTask_2: Jun 27 19:29:29.854: ec:85:2f:15:39:32
Doing local roaming for destination address
84:78:ac:f0:2a:94
*apfMsConnTask_2: Jun 27 19:29:29.854: ec:85:2f:15:39:32
Got 1 AKMs in RSNIE
*apfMsConnTask_2: Jun 27 19:29:29.854: ec:85:2f:15:39:32
RSNIE AKM matches with PMK cache entry :0x4
*apfMsConnTask_2: Jun 27 19:29:29.854: ec:85:2f:15:39:32
Created a new preauth entry for AP:84:78:ac:f0:2a:94
*apfMsConnTask_2: Jun 27 19:29:29.854: Adding MDIE,
ID is:0xaaf0
*apfMsConnTask_2: Jun 27 19:29:29.867: Processing assoc-req
station:ec:85:2f:15:39:32 AP:84:78:ac:f0:2a:90-00
thread:144bef38
*apfMsConnTask_2: Jun 27 19:29:29.867: ec:85:2f:15:39:32
Reassociation received from mobile on BSSID
84:78:ac:f0:2a:94
*apfMsConnTask_2: Jun 27 19:29:29.868: ec:85:2f:15:39:32
Marking this mobile as TGr capable.
*apfMsConnTask_2: Jun 27 19:29:29.868: ec:85:2f:15:39:32
Processing RSN IE type 48, length 38 for mobile
ec:85:2f:15:39:32
*apfMsConnTask_2: Jun 27 19:29:29.869: ec:85:2f:15:39:32
Roaming succeed for this client.
*apfMsConnTask_2: Jun 27 19:29:29.869: Sending assoc-resp
station:ec:85:2f:15:39:32 AP:84:78:ac:f0:2a:90-00
thread:144bef38
*apfMsConnTask_2: Jun 27 19:29:29.869: Adding MDIE,
ID is:0xaaf0
*apfMsConnTask_2: Jun 27 19:29:29.869: ec:85:2f:15:39:32
Including FT Mobility Domain IE (length 5) in
reassociation assoc Resp to mobile
*apfMsConnTask_2: Jun 27 19:29:29.870: ec:85:2f:15:39:32
Sending Assoc Response to station on BSSID
84:78:ac:f0:2a:94 (status 0) ApVapId 5 Slot 0
*dot1xMsgTask: Jun 27 19:29:29.874: ec:85:2f:15:39:32
Finishing FT roaming for mobile ec:85:2f:15:39:32
Como se muestra en la imagen, una vez que se negocia la transición rápida de BSS tras la asociación inicial a la WLAN, las cuatro tramas que se utilizan y se requieren para el roaming (autenticación de sistema abierto del cliente, autenticación de sistema abierto del AP, solicitud de reasociación y respuesta de reasociación) se utilizan básicamente como un protocolo de enlace de 4 vías de FT para derivar la nueva PTK (clave de cifrado de unidifusión) y GTK (clave de cifrado de multidifusión/difusión).
Esto sustituye al protocolo de enlace de 4 vías que normalmente ocurre después de intercambiar estas tramas, y el contenido FT y la negociación de clave en estas tramas es básicamente el mismo si utiliza 802.1X/EAP o PSK como método de seguridad. Como se muestra en la imagen, el campo AKM es la diferencia principal, que confirma si el cliente realiza FT con PSK o 802.1X. Por lo tanto, es importante tener en cuenta que estas cuatro tramas normalmente no tienen este tipo de información de seguridad para la negociación de clave, sino solo cuando el cliente FT se desplaza si 802.11r se implementa y negocia entre el cliente y la infraestructura WLAN en la asociación inicial.
802.11r permite otra implementación de Fast BSS Transition, en la que el cliente inicia el roaming de FT con el nuevo AP para el que el cliente se desplaza sobre el DS (sistema de distribución), y no sobre la marcha. En este caso, las tramas de la acción FT se utilizan para iniciar la negociación de clave en lugar de las tramas de la autenticación de sistema abierto.
Básicamente, una vez que el cliente decide que puede vagar a un mejor AP, el cliente envía una trama de solicitud de acción de FT al AP original donde está conectado actualmente antes de la itinerancia. El cliente indica el BSSID (dirección MAC) del AP de destino en el que desea realizar el roaming de FT. El AP original reenvía esta trama de solicitud de acción de FT al AP de destino a través del sistema de distribución (normalmente la infraestructura cableada), y el AP de destino responde al cliente con una trama de respuesta de acción de FT (también a través del DS, por lo que finalmente puede enviarlo por el aire al cliente). Una vez que este intercambio de tramas de acción FT es exitoso, el cliente finaliza el roaming FT; el cliente envía la solicitud de reasociación al AP de destino (esta vez por el aire) y recibe una respuesta de reasociación del nuevo AP para confirmar la derivación de las claves de itinerancia y final.
En resumen, hay cuatro tramas para negociar la transición rápida de BSS y derivar nuevas claves de cifrado, pero aquí las tramas de autenticación de sistema abierto se sustituyen por las tramas de solicitud/respuesta de acción de FT, que se intercambian con el AP de destino sobre el sistema de distribución con el AP actual. Este método también es válido para los métodos de seguridad 802.1X/EAP y PSK, todos soportados por los controladores de LAN inalámbrica de Cisco; sin embargo, dado que esta transición Over-the-DS no es soportada e implementada por la mayoría de los clientes inalámbricos en la industria Wi-Fi (y dado que las salidas de intercambio de tramas y de depuración son básicamente las mismas), no se proporcionan ejemplos en este documento. En su lugar, esta imagen se utiliza para visualizar la transición rápida de BSS sobre el DS:
Para solucionar este problema, la infraestructura de LAN inalámbrica de Cisco ha introducido la función 802.11r adaptable. Cuando el modo FT está configurado en Adaptive en el nivel WLAN, WLAN anuncia el ID de dominio de movilidad 802.11r en una WLAN habilitada para 802.11i. Algunos dispositivos cliente Apple iOS10 identifican la presencia de MDIE en una WLAN 80211i/WPA2 y realizan un intercambio de señales propietario para establecer una asociación 802.11r. Una vez que el cliente completa la asociación exitosa de 802.11r, puede realizar el roaming de FT como en una WLAN normal habilitada para 802.11r. El FT Adaptive solo es aplicable a los dispositivos Apple iOS10 (y posteriores) seleccionados. El resto de los clientes pueden seguir teniendo una asociación 802.11i/WPA2 en la WLAN y realizar el método FSR aplicable como se admita.
Encontrará más documentación sobre esta nueva función introducida para que los dispositivos iOS10 ejecuten 802.11r en una WLAN/SSID donde 802.11r no está realmente habilitado (de modo que otros clientes que no sean 802.11r puedan conectarse correctamente) en Prácticas recomendadas empresariales para dispositivos Cisco IOS en LAN inalámbrica de Cisco.
Revisión | Fecha de publicación | Comentarios |
---|---|---|
2.0 |
09-Feb-2023 |
Formato actualizado e información técnica verificada. Recertificación. |
1.0 |
02-Sep-2013 |
Versión inicial |