Configuring 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
This chapter describes how to configure IEEE 802.1X port-based authentication to prevent unauthorized
devices (clients) from gaining access to the network.
Note For complete syntax and usage information for the commands used in this chapter, refer to the Cisco IOS
Master Command List, Release 12.2SX at this URL:
http://www.cisco.com/en/US/docs/ios/mcl/122sxmcl/12_2sx_mcl_book.html
Tip For additional information about Cisco Catalyst 6500 Series Switches (including configuration examples
and troubleshooting information), see the documents listed on this page:
http://www.cisco.com/en/US/products/hw/switches/ps708/tsd_products_support_series_home.html
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-1
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Understanding 802.1X Port-Based Authentication
Device Roles
With 802.1X port-based authentication, the devices in the network have specific roles as shown in
Figure 46-1.
Authentication
Catalyst switch server
or
Cisco Router (RADIUS)
Workstations
(clients)
79549
Note To resolve Windows XP network connectivity and 802.1X port-based authentication issues,
read the Microsoft Knowledge Base article at this URL:
http://support.microsoft.com/kb/q303597/
• Authentication server—Performs the actual authentication of the client. The authentication server
validates the identity of the client and notifies the switch whether or not the client is authorized to
access the LAN and switch services. Because the switch acts as the proxy, the authentication service
is transparent to the client. The Remote Authentication Dial-In User Service (RADIUS) security
system with Extensible Authentication Protocol (EAP) extensions is the only supported
authentication server; it is available in Cisco Secure Access Control Server, version 3.0. RADIUS
uses a client-server model in which secure authentication information is exchanged between the
RADIUS server and one or more RADIUS clients.
• Switch (also called the authenticator and back-end authenticator)—Controls the physical access to
the network based on the authentication status of the client. The switch acts as an intermediary
(proxy) between the client and the authentication server, requesting identity information from the
client, verifying that information with the authentication server, and relaying a response to the
client. The switch includes the RADIUS client, which is responsible for encapsulating and
decapsulating the EAP frames and interacting with the authentication server.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-2 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Understanding 802.1X Port-Based Authentication
When the switch receives EAPOL frames and relays them to the authentication server, the Ethernet
header is stripped and the remaining EAP frame is reencapsulated in the RADIUS format. The EAP
frames are not modified or examined during encapsulation, and the authentication server must
support EAP within the native frame format. When the switch receives frames from the
authentication server, the server’s frame header is removed, leaving the EAP frame, which is then
encapsulated for Ethernet and sent to the client.
Note If 802.1X is not enabled or supported on the network access device, any EAPOL frames from the client
are dropped. If the client does not receive an EAP-request/identity frame after three attempts to start
authentication, the client transmits frames as if the port is in the authorized state. A port in the authorized
state effectively means that the client has been successfully authenticated. For more information, see the
“Ports in Authorized and Unauthorized States” section on page 46-4.
When the client supplies its identity, the switch begins its role as the intermediary, passing EAP frames
between the client and the authentication server until authentication succeeds or fails. If the
authentication succeeds, the switch port becomes authorized. For more information, see the “Ports in
Authorized and Unauthorized States” section on page 46-4.
The specific exchange of EAP frames depends on the authentication method being used. Figure 46-2
shows a message exchange initiated by the client using the One-Time-Password (OTP) authentication
method with a RADIUS server.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-3
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Understanding 802.1X Port-Based Authentication
EAPOL-Start
EAP-Request/Identity
EAP-Response/Identity RADIUS Access-Request
EAP-Request/OTP RADIUS Access-Challenge
EAP-Response/OTP RADIUS Access-Request
EAP-Success RADIUS Access-Accept
Port Authorized
EAPOL-Logoff
79551
Port Unauthorized
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-4 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Understanding 802.1X Port-Based Authentication
frame is received. The switch requests the identity of the client and begins relaying authentication
messages between the client and the authentication server. Each client attempting to access the
network is uniquely identified by the switch by using the client’s MAC address.
If the client is successfully authenticated (receives an Accept frame from the authentication server), the
port state changes to authorized, and all frames from the authenticated client are allowed through the
port. If the authentication fails, the port remains in the unauthorized state, but authentication can be
retried. If the authentication server cannot be reached, the switch can retransmit the request. If no
response is received from the server after the specified number of attempts, authentication fails, and
network access is not granted.
When a client logs off, it sends an EAPOL-logoff message, causing the switch port to transition to the
unauthorized state.
If the link state of a port transitions from up to down, or if an EAPOL-logoff frame is received, the port
returns to the unauthorized state.
Supported Topologies
The 802.1X port-based authentication is supported in two topologies:
• Point-to-point
• Wireless LAN
In a point-to-point configuration (see Figure 46-1 on page 46-2), only one client can be connected to the
802.1X-enabled switch port. The switch detects the client when the port link state changes to the up state.
If a client leaves or is replaced with another client, the switch changes the port link state to down, and
the port returns to the unauthorized state.
Figure 46-3 shows 802.1X port-based authentication in a wireless LAN. The 802.1X port is configured
as a multiple-host port that becomes authorized as soon as one client is authenticated. When the port is
authorized, all other hosts indirectly attached to the port are granted access to the network. If the port
becomes unauthorized (reauthentication fails or an EAPOL-logoff message is received), the switch
denies access to the network to all of the attached clients. In this topology, the wireless access point is
responsible for authenticating the clients attached to it, and the wireless access point acts as a client to
the switch.
Authentication
Catalyst switch server
Access point or
Cisco Router (RADIUS)
Wireless clients
79550
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-5
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Default 802.1X Port-Based Authentication Configuration
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-6 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
– Trunk port—If you try to enable 802.1X on a trunk port, an error message appears, and 802.1X
is not enabled. If you try to change the mode of an 802.1X-enabled port to trunk, the port mode
is not changed.
– EtherChannel port—Before enabling 802.1X on the port, you must first remove it from the
EtherChannel port-channel interface. If you try to enable 802.1X on an EtherChannel
port-channel interface or on an individual active port in an EtherChannel, an error message
appears, and 802.1X is not enabled. If you enable 802.1X on a not-yet active individual port of
an EtherChannel, the port does not join the EtherChannel.
– Secure port—You cannot configure a secure port as an 802.1X port. If you try to enable 802.1X
on a secure port, an error message appears, and 802.1X is not enabled. If you try to change an
802.1X-enabled port to a secure port, an error message appears, and the security settings are not
changed.
– Switch Port Analyzer (SPAN) destination port—You can enable 802.1X on a port that is a SPAN
destination port; however, 802.1X is disabled until the port is removed as a SPAN destination
port. You can enable 802.1X on a SPAN source port.
• The 802.1X protocol is not supported on ports configured with voice VLAN.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-7
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
Step 1 Router(config)# aaa new-model Enables AAA.
Router(config)# no aaa new-model Disables AAA.
Step 2 Router(config)# aaa authentication dot1x Creates an 802.1X port-based authentication method list.
{default} method1 [method2...]
Router(config)# no aaa authentication dot1x Clears the configured method list.
{default | list_name}
Step 3 Router(config)# dot1x system-auth-control Globally enables 802.1X port-based authentication.
Router(config)# no dot1x system-auth-control Globally disables 802.1X port-based authentication.
1
Step 4 Router(config)# interface type slot/port Enters interface configuration mode and specifies the
interface to be enabled for 802.1X port-based
authentication.
Step 5 Router(config-if)# dot1x port-control auto Enables 802.1X port-based authentication on the
interface.
Router(config-if)# no dot1x port-control auto Disables 802.1X port-based authentication on the
interface.
Step 6 Router(config)# end Returns to privileged EXEC mode.
Step 7 Router# show dot1x all Verifies your entries.
Check the Status column in the 802.1X Port Summary
section of the display. An enabled status means the
port-control value is set either to auto or to
force-unauthorized.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
When you enable 802.1X port-based authentication, note the following information:
• To create a default list that is used when a named list is not specified in the authentication
command, use the default keyword followed by the methods that are to be used in default situations.
The default method list is automatically applied to all interfaces.
• Enter at least one of these keywords:
– group radius—Use the list of all RADIUS servers for authentication.
– none—Use no authentication. The client is automatically authenticated by the switch without
using the information supplied by the client.
This example shows how to enable AAA and 802.1X on Fast Ethernet port 5/1:
Router# configure terminal
Router(config)# aaa new-model
Router(config)# aaa authentication dot1x default group radius
Router(config)# dot1x system-auth-control
Router(config)# interface fastethernet 5/1
Router(config-if)# dot1x port-control auto
Router(config-if)# end
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-8 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
Step 1 Router(config)# ip radius source-interface Specifies that the RADIUS packets have the IP address of
interface_name the indicated interface.
Router(config)# no ip radius source-interface Prevents the RADIUS packets from having the IP address
of the previously indicated interface.
Step 2 Router(config)# radius-server host {hostname | Configures the RADIUS server host name or IP address
ip_address} on the switch.
If you want to use multiple RADIUS servers, reenter this
command.
Router(config)# no radius-server host {hostname | Deletes the specified RADIUS server.
ip_address}
Step 3 Router(config)# radius-server key string Configures the authorization and encryption key used
between the switch and the RADIUS daemon running on
the RADIUS server.
Step 4 Router(config)# end Returns to privileged EXEC mode.
When you configure the RADIUS server parameters, note the following information:
• For hostname or ip_address, specify the host name or IP address of the remote RADIUS server.
• Specify the key string on a separate command line.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-9
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
• For key string, specify the authentication and encryption key used between the switch and the
RADIUS daemon running on the RADIUS server. The key is a text string that must match the
encryption key used on the RADIUS server.
• When you specify the key string, spaces within and at the end of the key are used. If you use spaces
in the key, do not enclose the key in quotation marks unless the quotation marks are part of the key.
This key must match the encryption used on the RADIUS daemon.
• You can globally configure the timeout, retransmission, and encryption key values for all RADIUS
servers by using the radius-server host global configuration command. If you want to configure
these options on a per-server basis, use the radius-server timeout, radius-server retransmit, and
the radius-server key global configuration commands. For more information, refer to the Cisco IOS
Security Configuration Guide, Release 12.2, publication and the Cisco IOS Security Command
Reference, Release 12.2, publication at this URL:
http://www.cisco.com/en/US/products/sw/iosswrel/ps1835/products_installation_and_configuratio
n_guides_list.html
Note You also need to configure some settings on the RADIUS server. These settings include the IP address
of the switch and the key string to be shared by both the server and the switch. For more information,
refer to the RADIUS server documentation.
This example shows how to configure the RADIUS server parameters on the switch:
Router# configure terminal
Router(config)# ip radius source-interface Vlan80
Router(config)# radius-server host 172.l20.39.46
Router(config)# radius-server key rad123
Router(config)# end
Command Purpose
Step 1 Router(config)# interface type1 slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x reauthentication Enables periodic reauthentication of the client, which is
disabled by default.
Router(config-if)# no dot1x reauthentication Disables periodic reauthentication of the client.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-10 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
Step 3 Router(config-if)# dot1x timeout reauth-period Sets the number of seconds between reauthentication
seconds attempts.
The range is 1 to 65535; the default is 3600 seconds.
This command affects the behavior of the switch only if
periodic reauthentication is enabled.
Router(config-if)# no dot1x timeout reauth-period Returns to the default reauthorization period.
Step 4 Router(config-if)# end Returns to privileged EXEC mode.
Step 5 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to enable periodic reauthentication and set the number of seconds between
reauthentication attempts to 4000:
Router(config-if)# dot1x reauthentication
Router(config-if)# dot1x timeout reauth-period 4000
Note Reauthentication does not disturb the status of an already authorized port.
Command Purpose
Step 1 Router# dot1x re-authenticate Manually reauthenticates the client connected to a port.
interface type1 slot/port
Step 2 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to manually reauthenticate the client connected to Fast Ethernet port 5/1:
Router# dot1x re-authenticate interface fastethernet 5/1
Starting reauthentication on FastEthernet 5/1
Note Initializing authentication disables any existing authentication before authenticating the client connected
to the port.
To initialize the authentication for the client connected to a port, perform this task:
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-11
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
Step 1 Router# dot1x initialize Initializes the authentication for the client connected to a
interface type1 slot/port port.
Step 2 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to initialize the authentication for the client connected to Fast Ethernet
port 5/1:
Router# dot1x initialize interface fastethernet 5/1
Starting reauthentication on FastEthernet 5/1
Command Purpose
1
Step 1 Router(config)# interface type slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x timeout quiet-period Sets the number of seconds that the switch remains in the
seconds quiet state following a failed authentication exchange
with the client.
The range is 0 to 65535 seconds; the default is 60.
Router(config-if)# no dot1x timeout quiet-period Returns to the default quiet time.
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to set the quiet time on the switch to 30 seconds:
Router(config-if)# dot1x timeout quiet-period 30
Note You should change the default value of this command only to adjust for unusual circumstances such as
unreliable links or specific behavioral problems with certain clients and authentication servers.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-12 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
To change the amount of time that the switch waits for client notification, perform this task:
Command Purpose
Step 1 Router(config)# interface type1 slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x timeout tx-period Sets the number of seconds that the switch waits for a
seconds response to an EAP-request/identity frame from the client
before retransmitting the request.
The range is 1 to 65535 seconds; the default is 30.
Router(config-if)# dot1x timeout tx-period Returns to the default retransmission time.
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to set 60 as the number of seconds that the switch waits for a response to an
EAP-request/identity frame from the client before retransmitting the request:
Router(config)# dot1x timeout tx-period 60
Command Purpose
1
Step 1 Router(config)# interface type slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x timeout supp-timeout Sets the switch-to-client retransmission time for the
seconds EAP-request frame.
Router(config-if)# no dot1x timeout supp-timeout Returns to the default retransmission time.
Step 3 Router# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to set the switch-to-client retransmission time for the EAP-request frame to
25 seconds:
Router(config-if)# dot1x timeout supp-timeout 25
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-13
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
1
Step 1 Router(config)# interface type slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x timeout server-timeout Sets the switch-to-authentication-server retransmission
seconds time for Layer 4 packets.
Router(config-if)# no dot1x timeout Returns to the default retransmission time.
server-timeout
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to set the switch-to-authentication-server retransmission time for Layer 4
packets to 25 seconds:
Router(config-if)# dot1x timeout server-timeout 25
Note You should change the default value of this command only to adjust for unusual circumstances such as
unreliable links or specific behavioral problems with certain clients and authentication servers.
Command Purpose
1
Step 1 Router(config)# interface type slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x max-req count Sets the number of times that the switch sends an
EAP-request/identity frame to the client before restarting
the authentication process. The range is 1 to 10; the
default is 2.
Router(config-if)# no dot1x max-req Returns to the default retransmission number.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-14 OL-3999-08
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Configuring 802.1X Port-Based Authentication
Command Purpose
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to set 5 as the number of times that the switch sends an EAP-request/identity
request before restarting the authentication process:
Router(config-if)# dot1x max-req 5
Command Purpose
Step 1 Router(config)# interface type1 slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x host-mode multi-host Allows multiple hosts (clients) on an 802.1X-authorized
port.
Note Make sure that the dot1x port-control interface
configuration command set is set to auto for the
specified interface.
Router(config-if)# dot1x host-mode single-host Disables multiple hosts on the port.
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
1
Step 4 Router# show dot1x interface type slot/port Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
This example shows how to enable 802.1X on Fast Ethernet interface 5/1 and to allow multiple hosts:
Router(config)# interface fastethernet 5/1
Router(config-if)# dot1x port-control auto
Router(config-if)# dot1x host-mode multi-host
Command Purpose
1
Step 1 Router(config)# interface type slot/port Selects an interface to configure.
Step 2 Router(config-if)# dot1x default Resets the configurable 802.1X parameters to the default
values.
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
OL-3999-08 46-15
Chapter 46 Configuring IEEE 802.1X Port-Based Authentication
Displaying 802.1X Status
Command Purpose
Step 3 Router(config-if)# end Returns to privileged EXEC mode.
Step 4 Router# show dot1x all Verifies your entries.
1. type = ethernet, fastethernet, gigabitethernet, or tengigabitethernet
Tip For additional information about Cisco Catalyst 6500 Series Switches (including configuration examples
and troubleshooting information), see the documents listed on this page:
http://www.cisco.com/en/US/products/hw/switches/ps708/tsd_products_support_series_home.html
Catalyst 6500 Series Switch Cisco IOS Software Configuration Guide, Release 12.2SXF
46-16 OL-3999-08