<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FSecurity%2FDiffie_Hellman</id>
		<title>Java Tutorial/Security/Diffie Hellman - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FSecurity%2FDiffie_Hellman"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Diffie_Hellman&amp;action=history"/>
		<updated>2026-04-07T03:43:17Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Security/Diffie_Hellman&amp;diff=4378&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Diffie_Hellman&amp;diff=4378&amp;oldid=prev"/>
				<updated>2010-06-01T05:02:05Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 05:02, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Security/Diffie_Hellman&amp;diff=4377&amp;oldid=prev</id>
		<title> в 17:44, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Security/Diffie_Hellman&amp;diff=4377&amp;oldid=prev"/>
				<updated>2010-05-31T17:44:27Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==  Diffie-Hellman Key Agreement ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.math.BigInteger;&lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.MessageDigest;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import javax.crypto.KeyAgreement;&lt;br /&gt;
import javax.crypto.spec.DHParameterSpec;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  private static BigInteger g512 = new BigInteger(&amp;quot;1234567890&amp;quot;, 16);&lt;br /&gt;
  private static BigInteger p512 = new BigInteger(&amp;quot;1234567890&amp;quot;, 16);&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());&lt;br /&gt;
    DHParameterSpec dhParams = new DHParameterSpec(p512, g512);&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(&amp;quot;DH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    keyGen.initialize(dhParams, new SecureRandom());&lt;br /&gt;
    KeyAgreement aKeyAgree = KeyAgreement.getInstance(&amp;quot;DH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyPair aPair = keyGen.generateKeyPair();&lt;br /&gt;
    KeyAgreement bKeyAgree = KeyAgreement.getInstance(&amp;quot;DH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyPair bPair = keyGen.generateKeyPair();&lt;br /&gt;
    aKeyAgree.init(aPair.getPrivate());&lt;br /&gt;
    bKeyAgree.init(bPair.getPrivate());&lt;br /&gt;
    aKeyAgree.doPhase(bPair.getPublic(), true);&lt;br /&gt;
    bKeyAgree.doPhase(aPair.getPublic(), true);&lt;br /&gt;
    MessageDigest hash = MessageDigest.getInstance(&amp;quot;SHA1&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    System.out.println(new String(hash.digest(aKeyAgree.generateSecret())));&lt;br /&gt;
    System.out.println(new String(hash.digest(bKeyAgree.generateSecret())));&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Diffie-Hellman with Elliptic Curve ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.math.BigInteger;&lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.MessageDigest;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import java.security.spec.ECFieldFp;&lt;br /&gt;
import java.security.spec.ECParameterSpec;&lt;br /&gt;
import java.security.spec.ECPoint;&lt;br /&gt;
import java.security.spec.EllipticCurve;&lt;br /&gt;
import javax.crypto.KeyAgreement;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(&amp;quot;ECDH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    EllipticCurve curve = new EllipticCurve(new ECFieldFp(new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffeffffffffffffffff&amp;quot;, 16)), new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffefffffffffffffffc&amp;quot;, 16), new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffefffffffffffffffc&amp;quot;, 16));&lt;br /&gt;
    ECParameterSpec ecSpec = new ECParameterSpec(curve, new ECPoint(new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffefffffffffffffffc&amp;quot;, 16), new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffefffffffffffffffc&amp;quot;, 16)), new BigInteger(&lt;br /&gt;
        &amp;quot;fffffffffffffffffffffffffffffffefffffffffffffffc&amp;quot;, 16), 1);&lt;br /&gt;
    keyGen.initialize(ecSpec, new SecureRandom());&lt;br /&gt;
    KeyAgreement aKeyAgree = KeyAgreement.getInstance(&amp;quot;ECDH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyPair aPair = keyGen.generateKeyPair();&lt;br /&gt;
    KeyAgreement bKeyAgree = KeyAgreement.getInstance(&amp;quot;ECDH&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyPair bPair = keyGen.generateKeyPair();&lt;br /&gt;
    aKeyAgree.init(aPair.getPrivate());&lt;br /&gt;
    bKeyAgree.init(bPair.getPrivate());&lt;br /&gt;
    aKeyAgree.doPhase(bPair.getPublic(), true);&lt;br /&gt;
    bKeyAgree.doPhase(aPair.getPublic(), true);&lt;br /&gt;
    MessageDigest hash = MessageDigest.getInstance(&amp;quot;SHA1&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    System.out.println(new String(hash.digest(aKeyAgree.generateSecret())));&lt;br /&gt;
    System.out.println(new String(hash.digest(bKeyAgree.generateSecret())));&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Generating a Parameter Set for the Diffie-Hellman Key Agreement Algorithm ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.security.AlgorithmParameterGenerator;&lt;br /&gt;
import java.security.AlgorithmParameters;&lt;br /&gt;
import javax.crypto.spec.DHParameterSpec;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    AlgorithmParameterGenerator paramGen = AlgorithmParameterGenerator.getInstance(&amp;quot;DH&amp;quot;);&lt;br /&gt;
    paramGen.init(1024);&lt;br /&gt;
    AlgorithmParameters params = paramGen.generateParameters();&lt;br /&gt;
    DHParameterSpec dhSpec = (DHParameterSpec) params.getParameterSpec(DHParameterSpec.class);&lt;br /&gt;
    System.out.println(&amp;quot;&amp;quot; + dhSpec.getP() + &amp;quot;,&amp;quot; + dhSpec.getG() + &amp;quot;,&amp;quot; + dhSpec.getL());&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Implementing the Diffie-Hellman key exchange ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.math.BigInteger;&lt;br /&gt;
import java.security.KeyFactory;&lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import javax.crypto.spec.DHParameterSpec;&lt;br /&gt;
import javax.crypto.spec.DHPublicKeySpec;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public final static int pValue = 47;&lt;br /&gt;
  public final static int gValue = 71;&lt;br /&gt;
  public final static int XaValue = 9;&lt;br /&gt;
  public final static int XbValue = 14;&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    BigInteger p = new BigInteger(Integer.toString(pValue));&lt;br /&gt;
    BigInteger g = new BigInteger(Integer.toString(gValue));&lt;br /&gt;
    BigInteger Xa = new BigInteger(Integer.toString(XaValue));&lt;br /&gt;
    BigInteger Xb = new BigInteger(Integer.toString(XbValue));&lt;br /&gt;
    createKey();&lt;br /&gt;
    int bitLength = 512; // 512 bits&lt;br /&gt;
    SecureRandom rnd = new SecureRandom();&lt;br /&gt;
    p = BigInteger.probablePrime(bitLength, rnd);&lt;br /&gt;
    g = BigInteger.probablePrime(bitLength, rnd);&lt;br /&gt;
    &lt;br /&gt;
    createSpecificKey(p, g);&lt;br /&gt;
  }&lt;br /&gt;
  public static void createKey() throws Exception {&lt;br /&gt;
    KeyPairGenerator kpg = KeyPairGenerator.getInstance(&amp;quot;DiffieHellman&amp;quot;);&lt;br /&gt;
    kpg.initialize(512);&lt;br /&gt;
    KeyPair kp = kpg.generateKeyPair();&lt;br /&gt;
    KeyFactory kfactory = KeyFactory.getInstance(&amp;quot;DiffieHellman&amp;quot;);&lt;br /&gt;
    DHPublicKeySpec kspec = (DHPublicKeySpec) kfactory.getKeySpec(kp.getPublic(),&lt;br /&gt;
        DHPublicKeySpec.class);&lt;br /&gt;
  }&lt;br /&gt;
  public static void createSpecificKey(BigInteger p, BigInteger g) throws Exception {&lt;br /&gt;
    KeyPairGenerator kpg = KeyPairGenerator.getInstance(&amp;quot;DiffieHellman&amp;quot;);&lt;br /&gt;
    DHParameterSpec param = new DHParameterSpec(p, g);&lt;br /&gt;
    kpg.initialize(param);&lt;br /&gt;
    KeyPair kp = kpg.generateKeyPair();&lt;br /&gt;
    KeyFactory kfactory = KeyFactory.getInstance(&amp;quot;DiffieHellman&amp;quot;);&lt;br /&gt;
    DHPublicKeySpec kspec = (DHPublicKeySpec) kfactory.getKeySpec(kp.getPublic(),&lt;br /&gt;
        DHPublicKeySpec.class);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>