 
              CSS441 Key Management Key Distribution Symmetric with Symmetric Key Management and Distribution Symmetric with Asymmetric Public Keys CSS441: Security and Cryptography X.509 Sirindhorn International Institute of Technology Thammasat University Prepared by Steven Gordon on 20 December 2015 css441y15s2l10, Steve/Courses/2015/s2/css441/lectures/key-management-and-distribution.tex, r4295 1/33
CSS441 Contents Key Management Key Distribution Key Distribution and Management Symmetric with Symmetric Symmetric with Asymmetric Symmetric Key Distribution using Symmetric Encryption Public Keys X.509 Symmetric Key Distribution using Asymmetric Encryption Distribution of Public Keys X.509 Certificates 2/33
CSS441 Key Management Key Management Challenges Key Distribution Symmetric with ◮ How to share a secret key? Symmetric Symmetric with ◮ How to obtain someone else’s public key? Asymmetric ◮ When to change keys? Public Keys X.509 Assumptions and Principles ◮ Many users wish to communicate securely across network ◮ Attacker can intercept any location in network ◮ Manual interactions between users are undesirable (e.g. physical exchange of keys) ◮ More times a key is used, greater chance for attacker to discover the key 3/33
CSS441 Where Should Encryption Be Performed? Key Management Key Distribution F A Symmetric with Symmetric SW1 SW5 R2 Symmetric with G B SW3 Asymmetric Public Keys R1 C R3 H X.509 SW4 D SW2 I R4 SW6 E J ◮ Number of keys to be exchanged depends on number of entities wishing to communicate ◮ Related issue: where to perform encryption ◮ Encrypt separately across each link ◮ Encrypt only at end-points 4/33
CSS441 Link Encryption vs End-to-End Encryption Key Management Link Encryption Key Distribution Symmetric with ◮ Encrypt data over individual links in network Symmetric Symmetric with ◮ Each link end-point shares a secret key Asymmetric ◮ Decrypt/Encrypt at each device in path Public Keys X.509 ◮ Requires all links/devices to support encryption End-to-End Encryption ◮ Encrypt data at network end-points (e.g. hosts or applications) ◮ Each pair of hosts/applications share a secret key ◮ Does not rely on intermediate network devices 5/33
CSS441 How Many Keys Need To Be Exchanged? Key Management Key Distribution F A Symmetric with Symmetric SW1 SW5 R2 Symmetric with G B SW3 Asymmetric Public Keys R1 C R3 H X.509 SW4 D SW2 I R4 SW6 E J ◮ Link-level encryption? ◮ End-to-end encryption between hosts? ◮ End-to-end encryption between applications? 6/33
CSS441 Exchanging Secret Keys Key Management Option 1: Manual Exchange of All Keys Key Distribution Symmetric with ◮ All users exchange secret keys with all other users Symmetric manually (e.g. face-to-face) Symmetric with Asymmetric ◮ Inconvenient Public Keys X.509 Option 2: Manual Exchange of Master Keys ◮ All users exchange master key with trusted, central entity (e.g. Key Distribution Centre) ◮ Session keys automatically exchanged between users via KDC ◮ Security and performance bottleneck at KDC 7/33
CSS441 Exchanging Secret Keys Key Management Option 3: Public Key Cryptography to Exchange Secrets Key Distribution Symmetric with ◮ Use public-key cryptography to securely and Symmetric automatically exchange secret keys Symmetric with Asymmetric ◮ Example 1: user A encrypts secret with user B’s public Public Keys key; sends to B X.509 ◮ Example 2: Diffie-Hellman secret key exchange ◮ Related issue: How to obtain someone else’s public key? 8/33
CSS441 Contents Key Management Key Distribution Key Distribution and Management Symmetric with Symmetric Symmetric with Asymmetric Symmetric Key Distribution using Symmetric Encryption Public Keys X.509 Symmetric Key Distribution using Asymmetric Encryption Distribution of Public Keys X.509 Certificates 9/33
CSS441 Symmetric Key Distribution using Symmetric Key Management Encryption Key Distribution ◮ Objective: two entities share same secret key Symmetric with Symmetric ◮ Principle: change keys frequently Symmetric with ◮ How to exchange a secret key? Asymmetric Public Keys 1. Decentralised Key Distribution: manual distribution of X.509 master keys between all entities, automatic distribution of session keys 2. Key Distribution Centre (KDC): manual distribution of master keys with KDC, automatic distribution of session keys 10/33
CSS441 Key Hierarchy and Lifetimes Key Management ◮ Master keys used to securely exchange session keys Key Distribution ◮ Session keys used to securely exchange data Symmetric with Symmetric ◮ Change session keys automatically and regularly Symmetric with Asymmetric ◮ Change master keys manually and seldom Public Keys ◮ Session key lifetime: X.509 ◮ Shorter lifetime is more secure; but increases overhead of exchanges ◮ Connection-oriented protocols (e.g. TCP): new session key for each connection ◮ Connection-less protocols (e.g. UDP/IP): change after fixed period or certain number of packets sent 11/33
CSS441 Notation Key Management ◮ End-systems: A and B , identified by ID A and ID B Key Distribution ◮ Master key (between A and B ): K m Symmetric with Symmetric ◮ Master keys specific to user: K a , K b Symmetric with Asymmetric ◮ Session key (between A and B ): K s Public Keys ◮ Nonce values: N 1 , N 2 X.509 ◮ Number used only once ◮ E.g. time-stamp, counter, random value, function f () ◮ Must be different for each request ◮ Must be difficult for attacker to guess 12/33
CSS441 Decentralised Key Distribution Key Management ◮ Each end-system must manually exchange n − 1 master Key Distribution keys ( K m ) with others Symmetric with Symmetric ◮ Does not rely on trusted-third party Symmetric with Asymmetric Public Keys X.509 Credit: Figure 14.5 in Stallings, Cryptography and Network Security , 5th Ed., Pearson 2011 13/33
CSS441 Using a Key Distribution Centre Key Management ◮ Key Distribution Centre (KDC) is trusted third party Key Distribution ◮ Users manually exchange master keys with KDC Symmetric with Symmetric ◮ Users automatically obtain session key (via KDC) to Symmetric with communicate with other users Asymmetric Public Keys X.509 14/33
CSS441 Key Distribution with KDC Key Management Key Distribution Symmetric with Symmetric Symmetric with Asymmetric Public Keys X.509 Credit: Figure 14.3 in Stallings, Cryptography and Network Security , 5th Ed., Pearson 2011 15/33
CSS441 Hierarchical Key Control Key Management ◮ Use multiple KDCs in a hierarchy Key Distribution ◮ E.g. KDC for each LAN (or building); central KDC to Symmetric with Symmetric exchange keys between hosts in different LANs Symmetric with ◮ Reduces effort in key distribution; limits damage if local Asymmetric Public Keys KDC is compromised X.509 16/33
CSS441 Contents Key Management Key Distribution Key Distribution and Management Symmetric with Symmetric Symmetric with Asymmetric Symmetric Key Distribution using Symmetric Encryption Public Keys X.509 Symmetric Key Distribution using Asymmetric Encryption Distribution of Public Keys X.509 Certificates 17/33
CSS441 Symmetric Key Distribution using Asymmetric Key Management Encryption Key Distribution ◮ Asymmetric encryption generally too slow for encrypting Symmetric with Symmetric large amount of data Symmetric with ◮ Common application of asymmetric encryption is Asymmetric Public Keys exchanging secret keys X.509 ◮ Three examples: 1. Simple Secret Key Distribution 2. Secret Key Distribution with Confidentiality and Authentication 3. Hybrid Scheme: Public-Key Distribution of KDC Master Keys 18/33
CSS441 Simple Secret Key Distribution Key Management ◮ Simple: no keys prior to or after communication Key Distribution ◮ Provides confidentiality for session key Symmetric with Symmetric ◮ Subject to man-in-the-middle attack Symmetric with Asymmetric ◮ Only useful if attacker cannot modify/insert messages Public Keys X.509 Credit: Figure 14.7 in Stallings, Cryptography and Network Security , 5th Ed., Pearson 2011 19/33
CSS441 Man-in-the-Middle Attack Key Management Key Distribution Symmetric with Symmetric Symmetric with Asymmetric Public Keys X.509 20/33
CSS441 Secret Key Distribution with Confidentiality and Key Management Authentication Key Distribution ◮ Provides both confidentiality and authentication in Symmetric with Symmetric exchange of secret key Symmetric with Asymmetric Public Keys X.509 Credit: Figure 14.8 in Stallings, Cryptography and Network Security , 5th Ed., Pearson 2011 21/33
CSS441 Hybrid Scheme: Public-Key Distribution of KDC Key Management Master Keys Key Distribution ◮ Use public-key distribution of secret keys when Symmetric with Symmetric exchanging master keys between end-systems and KDC Symmetric with ◮ Efficient method of delivering master keys (rather than Asymmetric Public Keys manual delivery) X.509 ◮ Useful for large networks, widely distributed set of users with single KDC 22/33
CSS441 Contents Key Management Key Distribution Key Distribution and Management Symmetric with Symmetric Symmetric with Asymmetric Symmetric Key Distribution using Symmetric Encryption Public Keys X.509 Symmetric Key Distribution using Asymmetric Encryption Distribution of Public Keys X.509 Certificates 23/33
Recommend
More recommend