Wireless Security

Download Report

Transcript Wireless Security

COEN 350
Mobile Security
Wireless Security

Wireless offers additional challenges:


Physical media can easily be sniffed.
War Driving

Legal?

U.S. federal computer crime statute, Title 18 U.S.C. 1030,
 Crime to knowingly access a computer used in interstate or
foreign communication "without authorization" and obtain
any information from the computer.
 Crime to access a computer without authorization with
"intent to defraud" to obtain "anything of value."
 But not if "the object of the fraud and the thing obtained
consists only of the use of the computer and the value of
such use is not more than $ 5,000 in any 1-year period."
Wireless Security

Wireless offers additional challenges:


Physical media can easily be sniffed.
Mobile computing needs to preserve
battery power.


Calculations cost more on a mobile platform.
Especially important for sensor networks
Wireless Security:
Attackers Perspective

Knowing the Threat

Targets of opportunity

Goal is



Targeted attacks


Internet access.
Easy pickings.
Targets assets valuable enough.
Internal attackers


Most Dangerous
Can open an unintentional security hole
IEEE 802.11

Wired Equivalent Privacy (WEP)
Protocol

Based on a shared secret k.



Distributed out of band.
Uses CRC for internal integrity protection.
Uses RC4 to encrypt network traffic.
WEP Protocol
WEP Protocol

Confidentiality




Original packet is first check-summed.
Checksum and data form the payload.
Transmitting device creates a 24-bit
random initialization vector IV.
IV and shared key are used to encrypt with
RC4
WEP Protocol

RC4

Generates a pseudo-random stream of
bytes (keystream)

Based on a secret internal state



Permutation S of all 256 possible bytes
Two index pointers
Plaintext is XORed with keystream
WEP Protocol

RC4

Key Scheduling Algorithm (KSA)

Initializes S based on a key
for i from 0 to 255
S[i] := i
j := 0
for i from 0 to 255
j := (j + S[i] + key[i mod keylength]) mod 256
swap(S[i],S[j])
WEP Protocol

RC4

Pseudo-Random Generation Algorithm
(PRGA)

Generates pseudo-random byte stream
i := 0
j := 0
while GeneratingOutput:
i := (i + 1) mod 256
j := (j + S[i]) mod 256
swap(S[i],S[j])
output S[(S[i] + S[j]) mod 256]
WEP Protocol

RC4

Known weaknesses

Keystream slightly biased


Fluhrer & McGrew attack can distinguish keystream
from random stream given a GB of input.
Fluhrer, Mantin, Shamir: statistics for output of the
first few bytes of output keystream are non-random,
leaking information about key.
WEP Protocol

Authentication


Station associating with access point needs
to authenticate itself.
Both exchange the type of authentication
that is accepted.


Open: Just identification between station and
AP
Shared Secret: Participants send nonces to
each other, encrypt the nonce using WEP (and
the shared secret key), and verify the other’s
response.
WEP has no key management


Everyone allowed to have access to a
wireless network has the same key.
Anyone with the key can read ALL
traffic.
WEP: RC4


RC4 uses the key and the IV to produce
a stream of pseudo-random bytes.
Calculates cipher text from plaintext by
XORing the pseudo-random stream with
the plain-text.
WEP: RC4
WEP: Attacks on RC4

Dictionary Attack





Build database:
224 different IVs
Build a database of 224 streams of MTU bytes
(2,312 B) for each different IV.
Takes < 40 GB storage.
XOR two entries with the same IV.


Result are the two plaintexts XORed.
Natural language text has enough redundancy
to decrypt the XOR of two text streams.
WEP: Attacks on RC4

Dictionary Attack



Many packages can be completely or
partially guessed.
XORing guessed plaintext and captured
cipher gives pseudo-random byte stream
for a given IV.
Some implementations reset IVs poorly.

This simplifies dictionary attacks.
WEP: Attacks on RC4

Injection Attack


Attacker creates packets on the wireless
connection.
Attacker XORs plaintext and cipher.

Builds Pseudo-Random Stream database
indexed by IV.
RC4
Fluhrer, Mantin, Shamir Attack

First few bits of several thousand
messages reveals key.

Based on an analysis of the RC4 code.

Originally kept secret, but later leaked on the
internet.
RC4
Fluhrer, Mantin, Shamir Attack

Key Scheduling Algorithm




Sets up RC4 state array S
S is a permutation of 0, 1, … 255
Output generator uses S to create a
pseudo-random sequence.
First byte of output is given by
S[S[1]+S[S[1]]].

First byte depends on

{S[1], S[S[1], S[S[1]+S[S[1]]}
RC4
Fluhrer, Mantin, Shamir Attack

Key Scheduling Algorithm

First byte of plain text package is part of the SNAP header


0xAA for IP and ARP packages
0xFF or 0xE0 for IPX
Guessing the first byte is trivial
Some IVs are vulnerable: “resolved”








(KeyByte+3, 0xFF, *)
Plus some more
Easy to test whether an IV is vulnerable.
Search for vulnerable IVs.
They leak key bytes probabilistically.
Large number of packets does it.
RC4
Fluhrer, Mantin, Shamir Attack


Optimization needs about 5,000,000 to
1,000,000 packages.
Counter-measures:


Change key frequently.
Change IV counters to avoid bad IVs.
WEP Message Modification


WEP uses CRC code to ascertain integrity of
messages.
CRC code is linear:




CRC(x  y) = CRC(x)  CRC(y).
Attacker knows plaintext M and desired modification
 for target plaintext M’ = M  .
Attacker want to substitute X = P(M,CRC(M)) for
P(M’,CRC(M’)).
Attacker sends
X(,CRC())
= P(M,CRC(M)) (,CRC())
= P(M’,CRC(M’))
Wireless Insecurity Problems

WiFi card software allows users to
change the MAC address.
Wireless Security

Casual user, low yield traffic


WEP is good enough.
Enterprise, Commercial

Combine WEP with higher order security



SSH
VPN
IPSec
WPA

Created by WiFi Alliance


Certification started April 2003
Uses 802.1X authentication server


Distributed different keys to each user.
Can also be used in “pre-shared key” (PSK)
mode


Every user uses the same passphrase.
Called WPA Personal
IEEE 802.1X

Standard for portbased authentication.

Uses a third-party
authentication server
such as Radius
http://www.linux.com/howtos/8021X-HOWTO/index.shtml
WPA

Protocol changes over WEP

CRC is replaced by “Michael” MIC.



MIC now includes a frame counter, preventing replay
attacks.
Payload bit flipping is now impossible.
Data encryption still uses RC4, but now

Prevents key recovery attacks on WEP by using



128b Key
48b Initialization vector
Temporal Key Integrity Protocol (TKIP) changes key
dynamically.
TKIP

Temporal Key Integrity Protocol

Ensures that every data packet has its own
encryption key.
802.11i



Uses AES instead of RC4.
Subset published as WPA2
Uses 802.1X authentication
Protocol Layers

WEP



Privacy only.
Very elementary security.
WPA

Temporal Key Exchange Protocol


AES: Advanced Encryption Standard



802.11i
Military grade encryption, replaces DES
802.1X


Fixes WEP that scrambles keys between packages and adds a secure
message check.
General purpose and extensible framework for authentication users
and generating / distributing keys.
Simple Secure Network (SSN)

Recipe for authentication based on 802.1X