360 likes | 655 Views
Security of Authentication Protocols. Alexander Potapov. Outline. Authentication definition Protocol architectures Cryptographic properties Freshness Types of attack on protocols T wo-way authentication protocol attack The Diffie-Hellman key exchange attack
E N D
Security of Authentication Protocols Alexander Potapov
Outline • Authentication definition • Protocol architectures • Cryptographic properties • Freshness • Types of attack on protocols • Two-way authentication protocol attack • The Diffie-Hellman key exchange attack • Authentication protocol using a KDC
Authentication definition • Authentication deals with the question of whether you are actually communicating with a specific process. • Authorization is concerned with what that process is permitted to do.
Authentication definition • Authentication deals with the question of whether you are actually communicating with a specific process. • Authorization is concerned with what that process is permitted to do. Example: • Is this actually Scott's process (authentication)? • Is Scott allowed to delete this file(authorization)? Delete file Server Request Scott
Protocol architectures • Existing cryptographic keys • Method of session key generation
Protocol architectures: existing cryptographic keys • The principals already share a secret key • An off-line server is used. Principals possess certified public keys • An on-line server is used. Each principal shares a key with a trusted server
Protocol architectures: existing cryptographic keys • The principals already share a secret key • An off-line server is used. Principals possess certified public keys • An on-line server is used. Each principal shares a key with a trusted server
Protocol architectures: existing cryptographic keys • The principals already share a secret key • An off-line server is used. Principals possess certified public keys • An on-line server is used. Each principal shares a key with a trusted server
Protocol architectures: method of session key generation • A key transport protocol • A key agreement protocol One of the principals generates the key and this key is then transferred to all protocol users (Ks in this example)
Protocol architectures: method of session key generation • A key transport protocol • A key agreement protocol Session key is a function of inputs by all protocol users
Cryptographic properties • Confidentiality • Data integrity • Data origin authentication • Non-repudiation Ensures that data is only available to those authorised to obtain it. Usually achieved through encryption/decryption.
Cryptographic properties • Confidentiality • Data integrity • Data origin authentication • Non-repudiation • Ensures that data has not been altered by • unauthorised entities. • Usually achieved: • Use of hash functions in combination with • encryption • Use of message authentication code to create • a separate check field
Cryptographic properties • Confidentiality • Data integrity • Data origin authentication • Non-repudiation Guarantees the origin of data. Normally achieved by the same mechanisms like we have in data integrity.
Cryptographic properties • Confidentiality • Data integrity • Data origin authentication • Non-repudiation Ensures that entities cannot deny sending data that they have committed to. Typically provided using a digital signature mechanism.
Freshness User of the session key should be able to verify that key is new and not replayed from old sessions. • Timestamps • Nonces (random challenges) • Counters On recipients side if message is within an acceptable window of the current time then the message is regarded as fresh.
Freshness User of the session key should be able to verify that key is new and not replayed from old sessions. • Timestamps • Nonces (random challenges) • Counters The message is fresh because the message cannot have been formed before the nonce was generated.
Freshness User of the session key should be able to verify that key is new and not replayed from old sessions. • Timestamps • Nonces (random challenges) • Counters The sender and recipient maintain a synchronized counter whose value is sent with the message and then incremented.
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction Eavesdropping The adversary captures the information sent in the protocol
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary alters the information sent in the protocol Modification
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary records information seen in the protocol and then sends it to the same, or a different, principal, possibly during a later protocol run Replay
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary engages in a run of the protocol prior to a run by the legitimate principals Preplay
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary sends protocol message back to the principal who sent them Reflection
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary prevents or hinders legitimate principals from completing the protocol Denial of service
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary replaces a protocol message field of one type with a message field of another type Typing attacks
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary gains some useful leverage from the protocol to help in cryptanalysis Cryptanalysis
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary chooses or modifies certificate information to attack one or more protocol runs Certificate manipulation
Types of attack on protocols • Eavesdropping • Modification • Replay • Preplay • Reflection • Denial of service • Typing attacks • Cryptanalysis • Certificate manipulation • Protocol interaction The adversary chooses a new protocol to interact with a known protocol Protocol interaction
Two-way authentication protocol A, B are the identities of Alice and Bob. Ri - the challenge, where the subscript identifies the challenger. Ki - are keys, where i indicates the owner.
Two-way authentication protocol: reflection attack Second session is opened (message 3), supplying the RB taken from message 2. Bob encrypts it and sends back KAB (RB) in message 4.
Two-way authentication protocol: solution of the problem • HMAC – hashed message authentication code • Data structured is hashed into the HMAC, for example using SHA-1. • Based on received information, Alice can compute the HMAC herself. Both HMACs include values chosen by the sending party, something which Trudy cannot control.
The Diffie-Hellman key exchange n and g are two agreed large numbers x and y are large (say, 512-bit) private numbers generated by both sides The trouble is, given only g mod n, it is hard to find x.All currently-known algorithms simply take too long, even on massively parallel supercomputers. x
The Diffie-Hellman key exchange: man-in-the-middle attack Alice thinks she is talking to Bob so she establishes a session key (with Trudy). So does Bob. Every message that Alice sends on the encrypted session is captured by Trudy, stored, modified if desired, and then (optionally) passed on to Bob. Similarly, in theother direction.
Authentication Using a Key Distribution Center: replayattack KDC - Key distribution center Ks - generated session key By snooping on the network, Trudy copies message 2 and the money-transfer request that follows it. Later, she replays both of them to Bob.
Authentication Using a Key Distribution Center:Needham-Schroederauthentication protocol ½ messages – ticket request (RA assures that message 2 is fresh, and not a replay) Message 4 - Bob sends back it to prove to Alice that she is talking to the real Bob
Reference Computer networks Andrew S. Tanenbaum Protocols for authentication and key establishment Colin Boyd, Anish Mathuria