KEMBAR78
Secure Communication (Distributed computing) | PPT
Secure Communication Paul Krzyzanowski [email_address] [email_address] Distributed Systems Except as otherwise noted, the content of this presentation is licensed under the Creative Commons Attribution 2.5 License.
Symmetric cryptography Both parties must agree on a secret key,  K message is encrypted, sent, decrypted at other side Key distribution must be secret otherwise messages can be decrypted users can be impersonated Alice Bob E K (P) D K (C )
Key explosion Each pair of users needs a separate key for secure communication Alice Bob K AB 2 users: 1 key Bob Alice K AB Charles K BC K AC 3 users: 3 keys 6 users: 15 keys 4 users: 6 keys 100 users: 4950 keys 1000 users: 399500 keys n  users:  keys
Key distribution Secure key distribution is the biggest problem with symmetric cryptography
Key exchange How can you communicate securely with someone you’ve never met? Whit Diffie: idea for a  public key  algorithm Challenge: can this be done securely? Knowledge of public key should not allow derivation of private key
Diffie-Hellman exponential key exchange Key distribution algorithm first algorithm to use public/private keys not public key encryption based on difficulty of computing discrete logarithms in a finite field compared with ease of calculating exponentiation Allows us to negotiate a secret session key without fear of eavesdroppers
Diffie-Hellman exponential key exchange All arithmetic performed in field of integers modulo some large number Both parties agree on a  large prime number  p and a  number    <  p Each party generates a public/private key pair private key for user  i :  X i  public key for user  i :  Y i  =
Diffie-Hellman exponential key exchange Alice has secret key  X A   Alice has public key  Y A   Alice computes Bob has secret key  X B   Bob has public key  Y B   K = (Bob’s public key)  (Alice’s private key)  mod p
Diffie-Hellman exponential key exchange Alice has secret key  X A   Alice has public key  Y A   Alice computes Bob has secret key  X B   Bob has public key  Y B   Bob computes K’ = (Alice’s public key)  (Bob’s private key)  mod p
Diffie-Hellman exponential key exchange Alice has secret key  X A   Alice has public key  Y A   Alice computes expanding: Bob has secret key  X B   Bob has public key  Y B   Bob computes expanding: K  is a  common key , known  only  to Bob and Alice K = K’
Diffie-Hellman example Alice picks X A  = 18 Alice’s public key is: Y A  = 7 18  mod 31667 = 6780 K = 22184 18  mod 31667 K = 14265 Bob picks  X B  = 27 Bob’s public key is: Y B  = 7 27  mod 31667 = 22184 K = 6780 27  mod 31667 K = 14265 Suppose  p =  31667,    = 7
Key distribution problem is solved! User maintains private key Publishes public key in database (“phonebook”) Communication begins with key exchange to establish a common key Common key can be used to encrypt a session key increase difficulty of breaking common key by reducing the amount of data we encrypt with it session key is valid only for one communication session
RSA: Public Key Cryptography Ron Rivest, Adi Shamir, Leonard Adleman created a true public key encryption algorithm in 1977 Each user generates two keys private key (kept secret) public key difficulty of algorithm based on the difficulty of factoring large numbers keys are functions of a pair of large (~200 digits) prime numbers
RSA algorithm Generate keys: choose two random large prime numbers  p ,  q Compute the product  n = pq   randomly choose the encryption key,  e , such that: e  and  ( p  - 1)( q  - 1)  are relatively prime use the extended Euclidean algorithm to compute the decryption key,  d :   ed   = 1 mod (( p  - 1) ( q  - 1))   d  = e -1  mod (( p  - 1) ( q  - 1)) discard  p ,  q
RSA algorithm Encrypt: divide data into numerical blocks <  n encrypt each block: c  =  m e  mod  n Decrypt: m  =  c d  mod  n
Communication with public key algorithms Different keys for encrypting and decrypting no need to worry about key distribution
Communication with public key algorithms Alice Bob Alice’s public key: K A Bob’s public key: K B exchange public keys (or look up in a directory/DB)
Communication with public key algorithms E B (P) D b (C) Alice Bob Alice’s public key: K A Bob’s public key: K B encrypt message with Bob’s public key decrypt message with Bob’s private key
Communication with public key algorithms E B (P) D b (C) Alice Bob Alice’s public key: K A Bob’s public key: K B D a (C) E A (P) decrypt message with Alice’s private key encrypt message with Alice’s public key encrypt message with Bob’s public key decrypt message with Bob’s private key
Public key woes Public key cryptography is great but: RSA about 100 times slower than DES in software, 1000 times slower in HW Vulnerable to chosen plaintext attack if you know the data is one of  n  messages, just encrypt each message with the recipient’s public key and compare It’s a good idea to reduce the amount of data encrypted with any given key but generating RSA keys is computationally very time consuming
Hybrid cryptosystems Use public key cryptography to encrypt a randomly generated symmetric key session key
Communication with a hybrid cryptosystem Alice Bob Bob’s public key: K B Get recipient’s public key (or fetch from directory/database)
Communication with a hybrid cryptosystem Alice Bob Bob’s public key: K B Pick random session key,  K E B ( K ) Encrypt session key with Bob’s public key Bob decrypts  K  with his private key K  = D b (E B ( K ))
Communication with a hybrid cryptosystem Alice Bob Bob’s public key: K B E B ( K ) K  = D b (E B ( K )) E K (P) D K (C) encrypt message using a symmetric algorithm and key  K decrypt message using a symmetric algorithm and key  K
Communication with a hybrid cryptosystem Alice Bob Bob’s public key: K B E B ( K ) K  = D b (E B ( K )) E K (P) D K (C) decrypt message using a symmetric algorithm and key  K encrypt message using a symmetric algorithm and key  K D K (C’) E K (P’)
Digital Signatures
Signatures We use signatures because a signature is: Authentic Unforgeable Not reusable   Non repudiatable Renders document unalterable Source: http://www.archives.gov/exhibits/charters/declaration.html
Signatures We use signatures because a signature is Authentic Unforgeable Not reusable   Non repudiatable Renders document unalterable ALL UNTRUE! Can we do better with  digital signatures ?
Digital signatures - arbitrated protocol Arbitrated protocol using symmetric encryption turn to trusted third party (arbiter) to authenticate messages Alice Bob Trent C=E A (P) Alice encrypts message for  herself  and sends it to Trent Trent is trusted and has everyone’s keys
Digital signatures - arbitrated protocol Alice Bob Trent P= D A (C) Trent receives Alice’s message and decrypts it with Alice’s key - this authenticates that it came from Alice - he may choose to log a hash of the message to   create a record of the transmission
Digital signatures - arbitrated protocol Alice Bob Trent Trent now encrypts the message for Bob and sends it to Bob C’= E B (P)
Digital signatures - arbitrated protocol Alice Bob Trent Bob receives the message and decrypts it   - it  must  have come from Trent since only Trent and Bob have Bob’s key - if the message says it’s from Alice, it must be - we trust Trent P’= D B (C’)
Digital signatures with multiple parties Bob can forward the message to Charles in the same manner. Trent can validate stored hash to ensure that Bob did not alter the message Alice Bob Trent Bob encrypts message with his key and sends it to Trent P’= D B (C’) Charles C’’= E B (P’)
Digital signatures with multiple parties Alice Bob Trent Trent decrypts the message   - knows it must be from Bob   - looks up ID to match original hash from Alice’s message - validates that the message has not been modified   - adds a “signed by Bob” indicator to the message Charles P’’= D B (C’’)
Digital signatures with multiple parties Alice Bob Trent Trent encrypts the new message for Charles Charles C’’’= E C (P’’)
Digital signatures with multiple parties Alice Bob Trent Charles decrypts the message - knows the message must have come from Trent - trusts Trent’s assertion that the message originated with Alice and was forwarded through Bob Charles P’’’= D C (C’’’)
Digital signatures - public key cryptography E a (P) D A (C) Alice Bob encrypt message with Alice’s private key decrypt message with Alice’s public key Encrypting a message with a private key is the same as signing! Directory of public keys
Digital signatures - public key cryptography What if Alice was sending Bob binary data? Bob might have a hard time knowing whether the decryption was successful or not Public key encryption is considerably slower than symmetric encryption what if the message is very large? What if we don’t want to hide the message, yet want a valid signature?
Digital signatures - public key cryptography Create a  hash  of the message Encrypt the hash  and send it with the message Validate the hash by decrypting it and comparing it with the hash of the received message The  signature  is now a distinct entity from the message
Digital signatures - public key cryptography Alice Bob H(P) Alice generates a hash of the message
Digital signatures - public key cryptography Alice Bob H(P) Alice encrypts the hash with her private key E a (H(P))
Digital signatures - public key cryptography Alice Bob H(P) Alice sends Bob the message and the encrypted hash E a (H(P))
Digital signatures - public key cryptography Alice Bob H(P) 1. Bob decrypts the has using Alice’s public key 2. Bob computes the hash of the message sent by Alice C = E a (H(P)) H(P) H’ = D A (C)
Digital signatures - public key cryptography Alice Bob H(P) If  the hashes match   - the encrypted hash  must  have been generated by Alice   - the signature is valid C = E a (H(P)) H(P) H’ = D A (C)
Digital signatures - multiple signers Bob Bob generates a hash (same as Alice’s) and encrypts it with his private key - sends Charles: {message, Alice’s encrypted hash, Bob’s encrypted hash} Alice H(P) C = E a (H(P)) C 2  = E b (H(P)) Charles
Digital signatures - multiple signers Bob Charles:   - generates a hash of the message: H(P) - decrypts Alice’s encrypted hash with Alice’s public key - validates Alice’s signature   - decrypts Bob’s encrypted hash with Bob’s public key - validates Bob’s signature Alice H(P) C = E a (H(P)) C 2  = E b (H(P)) Charles H 2  = D A (C 2 ) H 1  = D A (C)
Secure and authenticated messaging If we want secrecy of the message combine  encryption  with a  digital signature use a  session key : pick a random key,  K , to encrypt the message with a symmetric algorithm encrypt  K  with the public key of each recipient for signing, encrypt the hash of the message with sender’s private key
Secure and authenticated messaging Alice H(P) Alice generates a digital signature by encrypting the message digest with her private key. C 1  = E a (H(P))
Secure and authenticated messaging Alice H(P) Alice picks a random key,  K , and encrypts the message (P) with it using a symmetric algorithm. C 1  = E a (H(P)) C = E K (P)
Secure and authenticated messaging Alice H(P) Alice encrypts the session key for each recipient of this message: Bob and Charles using their public keys. C 1  = E a (H(P)) C = E K (P) K K C 2  = E B ( K ) K C 3  = E C ( K )
Secure and authenticated messaging Alice H(P) The aggregate message is sent to Bob and Charles C 1  = E a (H(P)) C = E K (P) K K C 2  = E B ( K ) K C 3  = E C ( K ) Message: Signature: Key for Bob: K K Key for Charles: Bob Charles Message from Alice
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob receives the message: - extracts key by decrypting it with his private key K  = E b (C 2 )
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob decrypts the message using  K K = E b (C 2 ) P = D K (C)
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob computes the hash of the message K  = E b (C 2 ) P = D K (C) H(P)
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob looks up Alice’s public key K  = E b (C 2 ) P = D K (C) H(P) Directory of public keys K A
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob decrypts Alice’s signature using Alice’s public key K  = E b (C 2 ) P = D K (C) H(P) H 1  = D A (C 1 )
Secure and authenticated messaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob validates Alice’s signature K = E b (C 2 ) P = D K (C) H(P) H 1  = D A (C 1 ) H 1  = H(P) ?
Cryptographic toolbox Symmetric encryption Public key encryption One-way hash functions Random number generators Nonces, session keys
Examples Key exchange Public key cryptography Key exchange + secure communication Public key + symmetric cryptography Authentication Nonce + encryption Message authentication codes Hashes Digital signature Hash + encryption
The end.

Secure Communication (Distributed computing)

  • 1.
    Secure Communication PaulKrzyzanowski [email_address] [email_address] Distributed Systems Except as otherwise noted, the content of this presentation is licensed under the Creative Commons Attribution 2.5 License.
  • 2.
    Symmetric cryptography Bothparties must agree on a secret key, K message is encrypted, sent, decrypted at other side Key distribution must be secret otherwise messages can be decrypted users can be impersonated Alice Bob E K (P) D K (C )
  • 3.
    Key explosion Eachpair of users needs a separate key for secure communication Alice Bob K AB 2 users: 1 key Bob Alice K AB Charles K BC K AC 3 users: 3 keys 6 users: 15 keys 4 users: 6 keys 100 users: 4950 keys 1000 users: 399500 keys n users: keys
  • 4.
    Key distribution Securekey distribution is the biggest problem with symmetric cryptography
  • 5.
    Key exchange Howcan you communicate securely with someone you’ve never met? Whit Diffie: idea for a public key algorithm Challenge: can this be done securely? Knowledge of public key should not allow derivation of private key
  • 6.
    Diffie-Hellman exponential keyexchange Key distribution algorithm first algorithm to use public/private keys not public key encryption based on difficulty of computing discrete logarithms in a finite field compared with ease of calculating exponentiation Allows us to negotiate a secret session key without fear of eavesdroppers
  • 7.
    Diffie-Hellman exponential keyexchange All arithmetic performed in field of integers modulo some large number Both parties agree on a large prime number p and a number  < p Each party generates a public/private key pair private key for user i : X i public key for user i : Y i =
  • 8.
    Diffie-Hellman exponential keyexchange Alice has secret key X A Alice has public key Y A Alice computes Bob has secret key X B Bob has public key Y B K = (Bob’s public key) (Alice’s private key) mod p
  • 9.
    Diffie-Hellman exponential keyexchange Alice has secret key X A Alice has public key Y A Alice computes Bob has secret key X B Bob has public key Y B Bob computes K’ = (Alice’s public key) (Bob’s private key) mod p
  • 10.
    Diffie-Hellman exponential keyexchange Alice has secret key X A Alice has public key Y A Alice computes expanding: Bob has secret key X B Bob has public key Y B Bob computes expanding: K is a common key , known only to Bob and Alice K = K’
  • 11.
    Diffie-Hellman example Alicepicks X A = 18 Alice’s public key is: Y A = 7 18 mod 31667 = 6780 K = 22184 18 mod 31667 K = 14265 Bob picks X B = 27 Bob’s public key is: Y B = 7 27 mod 31667 = 22184 K = 6780 27 mod 31667 K = 14265 Suppose p = 31667,  = 7
  • 12.
    Key distribution problemis solved! User maintains private key Publishes public key in database (“phonebook”) Communication begins with key exchange to establish a common key Common key can be used to encrypt a session key increase difficulty of breaking common key by reducing the amount of data we encrypt with it session key is valid only for one communication session
  • 13.
    RSA: Public KeyCryptography Ron Rivest, Adi Shamir, Leonard Adleman created a true public key encryption algorithm in 1977 Each user generates two keys private key (kept secret) public key difficulty of algorithm based on the difficulty of factoring large numbers keys are functions of a pair of large (~200 digits) prime numbers
  • 14.
    RSA algorithm Generatekeys: choose two random large prime numbers p , q Compute the product n = pq randomly choose the encryption key, e , such that: e and ( p - 1)( q - 1) are relatively prime use the extended Euclidean algorithm to compute the decryption key, d : ed = 1 mod (( p - 1) ( q - 1)) d = e -1 mod (( p - 1) ( q - 1)) discard p , q
  • 15.
    RSA algorithm Encrypt:divide data into numerical blocks < n encrypt each block: c = m e mod n Decrypt: m = c d mod n
  • 16.
    Communication with publickey algorithms Different keys for encrypting and decrypting no need to worry about key distribution
  • 17.
    Communication with publickey algorithms Alice Bob Alice’s public key: K A Bob’s public key: K B exchange public keys (or look up in a directory/DB)
  • 18.
    Communication with publickey algorithms E B (P) D b (C) Alice Bob Alice’s public key: K A Bob’s public key: K B encrypt message with Bob’s public key decrypt message with Bob’s private key
  • 19.
    Communication with publickey algorithms E B (P) D b (C) Alice Bob Alice’s public key: K A Bob’s public key: K B D a (C) E A (P) decrypt message with Alice’s private key encrypt message with Alice’s public key encrypt message with Bob’s public key decrypt message with Bob’s private key
  • 20.
    Public key woesPublic key cryptography is great but: RSA about 100 times slower than DES in software, 1000 times slower in HW Vulnerable to chosen plaintext attack if you know the data is one of n messages, just encrypt each message with the recipient’s public key and compare It’s a good idea to reduce the amount of data encrypted with any given key but generating RSA keys is computationally very time consuming
  • 21.
    Hybrid cryptosystems Usepublic key cryptography to encrypt a randomly generated symmetric key session key
  • 22.
    Communication with ahybrid cryptosystem Alice Bob Bob’s public key: K B Get recipient’s public key (or fetch from directory/database)
  • 23.
    Communication with ahybrid cryptosystem Alice Bob Bob’s public key: K B Pick random session key, K E B ( K ) Encrypt session key with Bob’s public key Bob decrypts K with his private key K = D b (E B ( K ))
  • 24.
    Communication with ahybrid cryptosystem Alice Bob Bob’s public key: K B E B ( K ) K = D b (E B ( K )) E K (P) D K (C) encrypt message using a symmetric algorithm and key K decrypt message using a symmetric algorithm and key K
  • 25.
    Communication with ahybrid cryptosystem Alice Bob Bob’s public key: K B E B ( K ) K = D b (E B ( K )) E K (P) D K (C) decrypt message using a symmetric algorithm and key K encrypt message using a symmetric algorithm and key K D K (C’) E K (P’)
  • 26.
  • 27.
    Signatures We usesignatures because a signature is: Authentic Unforgeable Not reusable Non repudiatable Renders document unalterable Source: http://www.archives.gov/exhibits/charters/declaration.html
  • 28.
    Signatures We usesignatures because a signature is Authentic Unforgeable Not reusable Non repudiatable Renders document unalterable ALL UNTRUE! Can we do better with digital signatures ?
  • 29.
    Digital signatures -arbitrated protocol Arbitrated protocol using symmetric encryption turn to trusted third party (arbiter) to authenticate messages Alice Bob Trent C=E A (P) Alice encrypts message for herself and sends it to Trent Trent is trusted and has everyone’s keys
  • 30.
    Digital signatures -arbitrated protocol Alice Bob Trent P= D A (C) Trent receives Alice’s message and decrypts it with Alice’s key - this authenticates that it came from Alice - he may choose to log a hash of the message to create a record of the transmission
  • 31.
    Digital signatures -arbitrated protocol Alice Bob Trent Trent now encrypts the message for Bob and sends it to Bob C’= E B (P)
  • 32.
    Digital signatures -arbitrated protocol Alice Bob Trent Bob receives the message and decrypts it - it must have come from Trent since only Trent and Bob have Bob’s key - if the message says it’s from Alice, it must be - we trust Trent P’= D B (C’)
  • 33.
    Digital signatures withmultiple parties Bob can forward the message to Charles in the same manner. Trent can validate stored hash to ensure that Bob did not alter the message Alice Bob Trent Bob encrypts message with his key and sends it to Trent P’= D B (C’) Charles C’’= E B (P’)
  • 34.
    Digital signatures withmultiple parties Alice Bob Trent Trent decrypts the message - knows it must be from Bob - looks up ID to match original hash from Alice’s message - validates that the message has not been modified - adds a “signed by Bob” indicator to the message Charles P’’= D B (C’’)
  • 35.
    Digital signatures withmultiple parties Alice Bob Trent Trent encrypts the new message for Charles Charles C’’’= E C (P’’)
  • 36.
    Digital signatures withmultiple parties Alice Bob Trent Charles decrypts the message - knows the message must have come from Trent - trusts Trent’s assertion that the message originated with Alice and was forwarded through Bob Charles P’’’= D C (C’’’)
  • 37.
    Digital signatures -public key cryptography E a (P) D A (C) Alice Bob encrypt message with Alice’s private key decrypt message with Alice’s public key Encrypting a message with a private key is the same as signing! Directory of public keys
  • 38.
    Digital signatures -public key cryptography What if Alice was sending Bob binary data? Bob might have a hard time knowing whether the decryption was successful or not Public key encryption is considerably slower than symmetric encryption what if the message is very large? What if we don’t want to hide the message, yet want a valid signature?
  • 39.
    Digital signatures -public key cryptography Create a hash of the message Encrypt the hash and send it with the message Validate the hash by decrypting it and comparing it with the hash of the received message The signature is now a distinct entity from the message
  • 40.
    Digital signatures -public key cryptography Alice Bob H(P) Alice generates a hash of the message
  • 41.
    Digital signatures -public key cryptography Alice Bob H(P) Alice encrypts the hash with her private key E a (H(P))
  • 42.
    Digital signatures -public key cryptography Alice Bob H(P) Alice sends Bob the message and the encrypted hash E a (H(P))
  • 43.
    Digital signatures -public key cryptography Alice Bob H(P) 1. Bob decrypts the has using Alice’s public key 2. Bob computes the hash of the message sent by Alice C = E a (H(P)) H(P) H’ = D A (C)
  • 44.
    Digital signatures -public key cryptography Alice Bob H(P) If the hashes match - the encrypted hash must have been generated by Alice - the signature is valid C = E a (H(P)) H(P) H’ = D A (C)
  • 45.
    Digital signatures -multiple signers Bob Bob generates a hash (same as Alice’s) and encrypts it with his private key - sends Charles: {message, Alice’s encrypted hash, Bob’s encrypted hash} Alice H(P) C = E a (H(P)) C 2 = E b (H(P)) Charles
  • 46.
    Digital signatures -multiple signers Bob Charles: - generates a hash of the message: H(P) - decrypts Alice’s encrypted hash with Alice’s public key - validates Alice’s signature - decrypts Bob’s encrypted hash with Bob’s public key - validates Bob’s signature Alice H(P) C = E a (H(P)) C 2 = E b (H(P)) Charles H 2 = D A (C 2 ) H 1 = D A (C)
  • 47.
    Secure and authenticatedmessaging If we want secrecy of the message combine encryption with a digital signature use a session key : pick a random key, K , to encrypt the message with a symmetric algorithm encrypt K with the public key of each recipient for signing, encrypt the hash of the message with sender’s private key
  • 48.
    Secure and authenticatedmessaging Alice H(P) Alice generates a digital signature by encrypting the message digest with her private key. C 1 = E a (H(P))
  • 49.
    Secure and authenticatedmessaging Alice H(P) Alice picks a random key, K , and encrypts the message (P) with it using a symmetric algorithm. C 1 = E a (H(P)) C = E K (P)
  • 50.
    Secure and authenticatedmessaging Alice H(P) Alice encrypts the session key for each recipient of this message: Bob and Charles using their public keys. C 1 = E a (H(P)) C = E K (P) K K C 2 = E B ( K ) K C 3 = E C ( K )
  • 51.
    Secure and authenticatedmessaging Alice H(P) The aggregate message is sent to Bob and Charles C 1 = E a (H(P)) C = E K (P) K K C 2 = E B ( K ) K C 3 = E C ( K ) Message: Signature: Key for Bob: K K Key for Charles: Bob Charles Message from Alice
  • 52.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob receives the message: - extracts key by decrypting it with his private key K = E b (C 2 )
  • 53.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob decrypts the message using K K = E b (C 2 ) P = D K (C)
  • 54.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob computes the hash of the message K = E b (C 2 ) P = D K (C) H(P)
  • 55.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob looks up Alice’s public key K = E b (C 2 ) P = D K (C) H(P) Directory of public keys K A
  • 56.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob decrypts Alice’s signature using Alice’s public key K = E b (C 2 ) P = D K (C) H(P) H 1 = D A (C 1 )
  • 57.
    Secure and authenticatedmessaging Message: Signature: Key for Bob: K K Key for Charles: Message from Alice Bob validates Alice’s signature K = E b (C 2 ) P = D K (C) H(P) H 1 = D A (C 1 ) H 1 = H(P) ?
  • 58.
    Cryptographic toolbox Symmetricencryption Public key encryption One-way hash functions Random number generators Nonces, session keys
  • 59.
    Examples Key exchangePublic key cryptography Key exchange + secure communication Public key + symmetric cryptography Authentication Nonce + encryption Message authentication codes Hashes Digital signature Hash + encryption
  • 60.