FACTOID # 160: Of all the nations of the world, China has the most people. But there are 71 nations that are more crowded.
 
 Home   Encyclopedia   Statistics   Countries A-Z   Flags   Maps   Education   Forum   FAQ   About 
 
WHAT'S NEW
RELATED ARTICLES
People who viewed "Diffie Hellman" also viewed:
RECENT ARTICLES
More Recent Articles »
 

FACTS & STATISTICS    Simple view

  1. Select countries to view: (hold down Control key and click to select several)

     

     

    Compare:

     

     

  1. Select fact or statistic: (* = graphable)

     

     

     

  2. (OPTIONAL) Compare to statistic: (both need to be graphable)

     

     

     

  3. View result as:

     

       
(OR) SEARCH ALL encyclopedia, stats & forums:   

Encyclopedia > Diffie Hellman

Diffie-Hellman key exchange is a cryptographic protocol which allows two parties to agree on a secret key over an insecure communication channel. Once the shared secret key has been established, they can use it to encrypt their secret communication using the conventional methods of cryptography. (The terms key agreement and key negotiation are also used. Arguably, these terms are more accurate as no keys are actually exchanged.)


The algorithm was first published by Whitfield Diffie and Martin Hellman in 1976, although it later emerged that it had been discovered a few years earlier within GCHQ, the British cryptography agency, by Malcolm Willamson but was kept classified. In 2002, Hellman suggested the algorithm be called Diffie-Hellman-Merkle key exchange in recognition of Ralph Merkle's contribution to the invention of public-key cryptography (Hellman, 2002).


Diffie-Hellman key agreement is used, in conjunction with several alternative authentication methods, in the IKE component of the IPsec protocol suite, for securing Internet Protocol communications.

Contents

History of the protocol

Diffie-Hellman key agreement was invented in 1976 during a collaboration between Whitfield Diffie and Martin Hellman and was the first practical method for establishing a shared secret over an unprotected communications channel. Ralph Merkle's work on public key distribution was an influence. John Gill suggested application of the discrete logarithm problem. It had been discovered by Malcolm Williamson of GCHQ in the UK some years previously, but GCHQ chose not make it public until 1997, by which time it had no influence on research in academia.


The method was followed shortly afterwards by RSA, another implementation of public key cryptography using asymmetric algorithms.


In 2002, Martin Hellman wrote:

"The system...has since become known as Diffie-Hellman key exchange. While that system was first described in a paper by Diffie and me, it is a public key distribution system, a concept developed by Merkle, and hence should be called 'Diffie-Hellman-Merkle key exchange' if names are to be associated with it. I hope this small pulpit might help in that endeavor to recognize Merkle's equal contribution to the invention of public key cryptography." [1] (http://www.comsoc.org/livepubs/ci1/public/anniv/pdfs/hellman.pdf)

U.S. Patent #4,200,770 [2] (http://patft.uspto.gov/netacgi/nph-Parser?Sect1=PTO1&Sect2=HITOFF&d=PALL&p=1&u=/netahtml/srchnum.htm&r=1&f=G&l=50&s1=4200770.WKU.&OS=PN/4200770&RS=PN/4200770), now expired, covers the algorithm and credits Hellman, Diffie, and Merkle as inventors.


Description

The simplest, and original, implementation of the protocol uses the multiplicative group of integers modulo p, where p is prime. That simply means that the integers between 1 and p − 1 are used with normal multiplication, exponentiation and division, except that after each operation the result keeps only the remainder after dividing by p. Here is an example of the protocol:

  1. Alice and Bob agree to use a prime number p=23 and base g=3.
  2. Alice chooses a secret integer a=6, then sends Bob ga mod p = 36 mod 23 = 16.
  3. Bob chooses a secret integer b=15, then sends Alice gb mod p = 315 mod 23 = 12.
  4. Alice computes (gb mod p)a mod p = 126 mod 23 = 9.
  5. Bob computes (ga mod p)b mod p = 1615 mod 23 = 9.

Both Alice and Bob have arrived at the same value, this is because gab and gba are equal. Note that only a, b, gab and gba are kept secret. All the other values are sent in the clear. Once Alice and Bob compute the shared secret they can use it as an encryption key, known only to them, for sending messages across the same open communications channel.


Of course, much larger values of a,b, and p would be needed to make this example secure, since it is easy to try all the possible values of gab mod 23. If p was a prime of more than 300 digits, and a and b were at least 100 digits long, then even the best known algorithms for finding a given only g, p, and ga mod p (known as the discrete logarithm problem) would take longer than the lifetime of the universe to run.


Here's a more general description of the protocol:

  1. Alice and Bob agree on a finite cyclic group G and a generating element g in G. (This is usually done long before the rest of the protocol; g is assumed to be known by all attackers.) We will write the group G multiplicatively.
  2. Alice picks a random natural number a and sends ga to Bob.
  3. Bob picks a random natural number b and sends gb to Alice.
  4. Alice computes (gb)a.
  5. Bob computes (ga)b.

Both Alice and Bob are now in possession of the group element gab which can serve as the shared secret key. The values of (gb)a and (ga)b are the same because groups are power associative. (See also exponentiation.)


Security

The protocol is considered secure against eavesdroppers if G and g are chosen properly. The eavesdropper ("Eve") must solve the Diffie-Hellman problem to obtain gab. This is currently considered difficult. An efficient algorithm to solve the discrete logarithm problem would make it easy to compute a or b and solve the Diffie-Hellman problem, making this protocol insecure.


The order of G should be prime or have a large prime factor to prevent use of the Pohlig-Hellman algorithm to obtain a or b. For this reason, a Sophie Germain prime q is often used to calculate p=2q+1, called a safe prime, since the order of p is then only divisible by 2 and q. g is then sometimes chosen to generate a subgroup of order q rather than being a true generator, so that the Legendre symbol of ga never reveals the low order bit of a.


If Alice and Bob use random number generators whose outputs are not completely random but can be predicted to some extent, then Eve's task is much easier.


The protocol is vulnerable to the man in the middle attack in which the attacker is able to read and modify all messages between Alice and Bob. As g is not secret, the attacker can easily create his own power of g and send that to Bob. When Bob replies, the attacker intercepts the message and will share his key with Bob. Authentication is hence needed. Workarounds exist, such as digitally signing each message, which is possible if Alice and Bob have a public key infrastructure.


References

Cryptographic apparatus and method] Martin E. Hellman, Bailey W. Diffie, and Ralph C. Merkle, U.S. Patent #4,200,770, 29 April 1980]

External links

  • RFC 2631, Diffie-Hellman Key Agreement Method E. Rescorla June 1999. Full text of RFC 2631 (http://www.ietf.org/rfc/rfc2631.txt)
  • Summary of ANSI X9.42: Agreement of Symmetric Keys Using Discrete Logarithm Cryptography (http://csrc.nist.gov/encryption/kms/summary-x9-42.pdf) (64K PDF file) (Description of ANSI 9 Standards (http://www.rsasecurity.com/rsalabs/node.asp?id=2306))

  Results from FactBites:
 
Diffie-Hellman key exchange - Wikipedia, the free encyclopedia (1212 words)
The scheme was first published publicly by Whitfield Diffie and Martin Hellman in 1976, although it later emerged that it had been discovered a few years earlier within GCHQ, the British signals intelligence agency, by Malcolm J. Williamson but was kept classified.
In 2002, Hellman suggested the algorithm be called Diffie-Hellman-Merkle key exchange in recognition of Ralph Merkle's contribution to the invention of public-key cryptography (Hellman, 2002).
Diffie-Hellman key agreement was invented in 1976 during a collaboration between Whitfield Diffie and Martin Hellman and was the first practical method for establishing a shared secret over an unprotected communications channel.
ICS 54: History of Public-Key Cryptography (3659 words)
The patent granted to Diffie and Hellman is the first of a group that emerged from scientists at Stanford University and the Massachusetts Institute of Technology during the end of the 1970's.
By everyone's estimation, the invention by Diffie and Hellman was a pivotal moment in network security, a crucial component of public privacy, and also an elegant and simple mathematical solution.
While Diffie was technically a graduate student at the time, both he and his nominal adviser, Hellman, both agree that this was more a convenient classification that made it easier for Hellman to use research money to provide support.
  More results at FactBites »


 

COMMENTARY     


Share your thoughts, questions and commentary here
Your name
Your comments
Please enter the 5-letter protection code

Want to know more?
Search encyclopedia, statistics and forums:

 


Lesson Plans | Student Area | Student FAQ | Reviews | Press Releases |  Feeds | Contact
The Wikipedia article included on this page is licensed under the GFDL.
Images may be subject to relevant owners' copyright.
All other elements are (c) copyright NationMaster.com 2003-5. All Rights Reserved.
Usage implies agreement with terms.