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

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Security/Key_Generator&amp;diff=7617&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Security/Key_Generator&amp;diff=7617&amp;oldid=prev"/>
				<updated>2010-06-01T06:48:55Z</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;Версия 06:48, 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://www.jexp.ru/index.php?title=Java/Security/Key_Generator&amp;diff=7616&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Security/Key_Generator&amp;diff=7616&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:45Z</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;== Asymmetric Key Maker ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    String algorithm = &amp;quot;&amp;quot;;&lt;br /&gt;
    KeyPair keyPair = KeyPairGenerator.getInstance(algorithm).generateKeyPair();&lt;br /&gt;
    System.out.println(keyPair.getPublic());&lt;br /&gt;
    System.out.println(keyPair.getPrivate());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Generate a 1024-bit RSA key pair ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(&amp;quot;RSA&amp;quot;);&lt;br /&gt;
    keyGen.initialize(1024);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Generate a 576-bit DH key pair ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(&amp;quot;DH&amp;quot;);&lt;br /&gt;
    keyGen.initialize(576);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
  }&lt;br /&gt;
}   &lt;br /&gt;
   &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;
== Generate a key for the HMAC-SHA1 keyed-hashing 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;
  &lt;br /&gt;
import javax.crypto.KeyGenerator;&lt;br /&gt;
import javax.crypto.SecretKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    KeyGenerator keyGen = KeyGenerator.getInstance(&amp;quot;HmacMD5&amp;quot;);&lt;br /&gt;
    SecretKey key = keyGen.generateKey();&lt;br /&gt;
    // Generate a key for the HMAC-SHA1 keyed-hashing algorithm&lt;br /&gt;
    keyGen = KeyGenerator.getInstance(&amp;quot;HmacSHA1&amp;quot;);&lt;br /&gt;
    key = keyGen.generateKey();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Generate DSA key pair ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    KeyPairGenerator kpg = KeyPairGenerator.getInstance(&amp;quot;DSA&amp;quot;);&lt;br /&gt;
    kpg.initialize(1024, new SecureRandom());&lt;br /&gt;
    KeyPair dsaKeyPair = kpg.generateKeyPair();&lt;br /&gt;
  }&lt;br /&gt;
}&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 Public/Private Key Pair ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    // Generate a 1024-bit Digital Signature Algorithm (DSA) key pair&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(&amp;quot;DSA&amp;quot;);&lt;br /&gt;
    keyGen.initialize(1024);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    System.out.println(privateKey);&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
    System.out.println(publicKey);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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 Symmetric Key ==&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;
  &lt;br /&gt;
import javax.crypto.KeyGenerator;&lt;br /&gt;
import javax.crypto.SecretKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    // Generate a DES key&lt;br /&gt;
    KeyGenerator keyGen = KeyGenerator.getInstance(&amp;quot;DES&amp;quot;);&lt;br /&gt;
    SecretKey key = keyGen.generateKey();&lt;br /&gt;
    // Generate a Blowfish key&lt;br /&gt;
    keyGen = KeyGenerator.getInstance(&amp;quot;Blowfish&amp;quot;);&lt;br /&gt;
    key = keyGen.generateKey();&lt;br /&gt;
    // Generate a triple DES key&lt;br /&gt;
    keyGen = KeyGenerator.getInstance(&amp;quot;DESede&amp;quot;);&lt;br /&gt;
    key = keyGen.generateKey();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Get the bytes of the public and private keys ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    String algorithm = &amp;quot;DSA&amp;quot;; // or RSA, DH, etc.&lt;br /&gt;
    // Generate a 1024-bit Digital Signature Algorithm (DSA) key pair&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(algorithm);&lt;br /&gt;
    keyGen.initialize(1024);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
    byte[] privateKeyBytes = privateKey.getEncoded();&lt;br /&gt;
    byte[] publicKeyBytes = publicKey.getEncoded();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Getting the Bytes of a Generated Key Pair ==&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;
  &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    String algorithm = &amp;quot;DSA&amp;quot;; // or RSA, DH, etc.&lt;br /&gt;
    // Generate a 1024-bit Digital Signature Algorithm (DSA) key pair&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(algorithm);&lt;br /&gt;
    keyGen.initialize(1024);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Key Generator Mac ==&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;
 &lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import javax.crypto.KeyGenerator;&lt;br /&gt;
import javax.crypto.Mac;&lt;br /&gt;
import javax.crypto.SecretKey;&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;
    String inputString = &amp;quot;www.jexp.ru&amp;quot;;&lt;br /&gt;
    KeyGenerator keyGen = KeyGenerator.getInstance(&amp;quot;HmacMD5&amp;quot;);&lt;br /&gt;
    SecretKey secretKey = keyGen.generateKey();&lt;br /&gt;
    Mac mac = Mac.getInstance(secretKey.getAlgorithm());&lt;br /&gt;
    mac.init(secretKey);&lt;br /&gt;
    byte[] byteData = inputString.getBytes(&amp;quot;UTF8&amp;quot;);&lt;br /&gt;
    byte[] macBytes = mac.doFinal(byteData);&lt;br /&gt;
    String macAsString = new sun.misc.BASE64Encoder().encode(macBytes);&lt;br /&gt;
    System.out.println(&amp;quot;Authentication code is: &amp;quot; + macAsString);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &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;
&lt;br /&gt;
== KeyPair Generator For Private Key ==&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;
 &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PrivateKey;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public KeyPair generateKeyPair(long seed)throws Exception {&lt;br /&gt;
    Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());&lt;br /&gt;
    KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(&amp;quot;DSA&amp;quot;);&lt;br /&gt;
    SecureRandom rng = SecureRandom.getInstance(&amp;quot;SHA1PRNG&amp;quot;, &amp;quot;SUN&amp;quot;);&lt;br /&gt;
    rng.setSeed(seed);&lt;br /&gt;
    keyGenerator.initialize(1024, rng);&lt;br /&gt;
    return (keyGenerator.generateKeyPair());&lt;br /&gt;
  }&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    MainClass kpge = new MainClass();&lt;br /&gt;
    KeyPair kp = kpge.generateKeyPair(999);&lt;br /&gt;
    System.out.println(&amp;quot;\n-- Private Key ----&amp;quot;);&lt;br /&gt;
    PrivateKey priKey = kp.getPrivate();&lt;br /&gt;
    System.out.println(&amp;quot;   Algorithm=&amp;quot; + priKey.getAlgorithm());&lt;br /&gt;
    System.out.println(&amp;quot;   Encoded=&amp;quot; + priKey.getEncoded());&lt;br /&gt;
    System.out.println(&amp;quot;   Format=&amp;quot; + priKey.getFormat());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &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;
&lt;br /&gt;
== KeyPair Generator For Public Key ==&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;
 &lt;br /&gt;
import java.security.KeyPair;&lt;br /&gt;
import java.security.KeyPairGenerator;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
import java.security.SecureRandom;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  public KeyPair generateKeyPair(long seed)throws Exception {&lt;br /&gt;
    Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());&lt;br /&gt;
    KeyPairGenerator keyGenerator = KeyPairGenerator.getInstance(&amp;quot;DSA&amp;quot;);&lt;br /&gt;
    SecureRandom rng = SecureRandom.getInstance(&amp;quot;SHA1PRNG&amp;quot;, &amp;quot;SUN&amp;quot;);&lt;br /&gt;
    rng.setSeed(seed);&lt;br /&gt;
    keyGenerator.initialize(1024, rng);&lt;br /&gt;
    return (keyGenerator.generateKeyPair());&lt;br /&gt;
  }&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    MainClass kpge = new MainClass();&lt;br /&gt;
    KeyPair kp = kpge.generateKeyPair(999);&lt;br /&gt;
    System.out.println(&amp;quot;-- Public Key ----&amp;quot;);&lt;br /&gt;
    PublicKey pubKey = kp.getPublic();&lt;br /&gt;
    System.out.println(&amp;quot;   Algorithm=&amp;quot; + pubKey.getAlgorithm());&lt;br /&gt;
    System.out.println(&amp;quot;   Encoded=&amp;quot; + pubKey.getEncoded());&lt;br /&gt;
    System.out.println(&amp;quot;   Format=&amp;quot; + pubKey.getFormat());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &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;
&lt;br /&gt;
== The bytes can be converted back to public and private key objects ==&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;
  &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.PrivateKey;&lt;br /&gt;
import java.security.PublicKey;&lt;br /&gt;
import java.security.spec.EncodedKeySpec;&lt;br /&gt;
import java.security.spec.PKCS8EncodedKeySpec;&lt;br /&gt;
import java.security.spec.X509EncodedKeySpec;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    String algorithm = &amp;quot;DSA&amp;quot;; // or RSA, DH, etc.&lt;br /&gt;
    // Generate a 1024-bit Digital Signature Algorithm (DSA) key pair&lt;br /&gt;
    KeyPairGenerator keyGen = KeyPairGenerator.getInstance(algorithm);&lt;br /&gt;
    keyGen.initialize(1024);&lt;br /&gt;
    KeyPair keypair = keyGen.genKeyPair();&lt;br /&gt;
    PrivateKey privateKey = keypair.getPrivate();&lt;br /&gt;
    PublicKey publicKey = keypair.getPublic();&lt;br /&gt;
    byte[] privateKeyBytes = privateKey.getEncoded();&lt;br /&gt;
    byte[] publicKeyBytes = publicKey.getEncoded();&lt;br /&gt;
    &lt;br /&gt;
    KeyFactory keyFactory = KeyFactory.getInstance(algorithm);&lt;br /&gt;
    EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(privateKeyBytes);&lt;br /&gt;
    PrivateKey privateKey2 = keyFactory.generatePrivate(privateKeySpec);&lt;br /&gt;
    EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(publicKeyBytes);&lt;br /&gt;
    PublicKey publicKey2 = keyFactory.generatePublic(publicKeySpec);&lt;br /&gt;
    // The orginal and new keys are the same&lt;br /&gt;
    boolean same = privateKey.equals(privateKey2); &lt;br /&gt;
    same = publicKey.equals(publicKey2); &lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &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;
== Using the KeyGenerator class and showing how to create a SecretKeySpec from an encoded key ==&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;
 &lt;br /&gt;
import java.security.Key;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import javax.crypto.Cipher;&lt;br /&gt;
import javax.crypto.KeyGenerator;&lt;br /&gt;
import javax.crypto.spec.IvParameterSpec;&lt;br /&gt;
import javax.crypto.spec.SecretKeySpec;&lt;br /&gt;
/**&lt;br /&gt;
 * Basic example using the KeyGenerator class and showing how to create a&lt;br /&gt;
 * SecretKeySpec from an encoded key.&lt;br /&gt;
 */&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;
    byte[] input = &amp;quot;www.jexp.ru&amp;quot;.getBytes();&lt;br /&gt;
    &lt;br /&gt;
    byte[] ivBytes = new byte[] { 0x00, 0x00, 0x00, 0x01, 0x04, 0x05, 0x06, 0x07, 0x00, 0x00, 0x00,&lt;br /&gt;
        0x00, 0x00, 0x00, 0x00, 0x01 };&lt;br /&gt;
    Cipher cipher = Cipher.getInstance(&amp;quot;AES/CTR/NoPadding&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyGenerator generator = KeyGenerator.getInstance(&amp;quot;AES&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    generator.init(192);&lt;br /&gt;
    Key encryptionKey = generator.generateKey();&lt;br /&gt;
    System.out.println(&amp;quot;key   : &amp;quot; + Utils.toHex(encryptionKey.getEncoded()));&lt;br /&gt;
    System.out.println(&amp;quot;input : &amp;quot; + new String(input));&lt;br /&gt;
    // encryption pass&lt;br /&gt;
    cipher.init(Cipher.ENCRYPT_MODE, encryptionKey, new IvParameterSpec(ivBytes));&lt;br /&gt;
    byte[] cipherText = new byte[cipher.getOutputSize(input.length)];&lt;br /&gt;
    int ctLength = cipher.update(input, 0, input.length, cipherText, 0);&lt;br /&gt;
    ctLength += cipher.doFinal(cipherText, ctLength);&lt;br /&gt;
    // decryption pass&lt;br /&gt;
    Key decryptionKey = new SecretKeySpec(encryptionKey.getEncoded(), encryptionKey.getAlgorithm());&lt;br /&gt;
    cipher.init(Cipher.DECRYPT_MODE, decryptionKey, new IvParameterSpec(ivBytes));&lt;br /&gt;
    byte[] plainText = new byte[cipher.getOutputSize(ctLength)];&lt;br /&gt;
    int ptLength = cipher.update(cipherText, 0, ctLength, plainText, 0);&lt;br /&gt;
    ptLength += cipher.doFinal(plainText, ptLength);&lt;br /&gt;
    System.out.println(&amp;quot;plain : &amp;quot; + new String(plainText) + &amp;quot; bytes: &amp;quot; + ptLength);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
class Utils&lt;br /&gt;
{&lt;br /&gt;
    private static String digits = &amp;quot;0123456789abcdef&amp;quot;;&lt;br /&gt;
    &lt;br /&gt;
    /**&lt;br /&gt;
     * Return length many bytes of the passed in byte array as a hex string.&lt;br /&gt;
     * &lt;br /&gt;
     * @param data the bytes to be converted.&lt;br /&gt;
     * @param length the number of bytes in the data block to be converted.&lt;br /&gt;
     * @return a hex representation of length bytes of data.&lt;br /&gt;
     */&lt;br /&gt;
    public static String toHex(byte[] data, int length)&lt;br /&gt;
    {&lt;br /&gt;
        StringBuffer  buf = new StringBuffer();&lt;br /&gt;
        &lt;br /&gt;
        for (int i = 0; i != length; i++)&lt;br /&gt;
        {&lt;br /&gt;
            int v = data[i] &amp;amp; 0xff;&lt;br /&gt;
            &lt;br /&gt;
            buf.append(digits.charAt(v &amp;gt;&amp;gt; 4));&lt;br /&gt;
            buf.append(digits.charAt(v &amp;amp; 0xf));&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
        return buf.toString();&lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
    /**&lt;br /&gt;
     * Return the passed in byte array as a hex string.&lt;br /&gt;
     * &lt;br /&gt;
     * @param data the bytes to be converted.&lt;br /&gt;
     * @return a hex representation of data.&lt;br /&gt;
     */&lt;br /&gt;
    public static String toHex(byte[] data)&lt;br /&gt;
    {&lt;br /&gt;
        return toHex(data, data.length);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
           &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;
&lt;br /&gt;
== Wrap And Unwrap Key ==&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;
 &lt;br /&gt;
import java.security.Key;&lt;br /&gt;
import java.security.Security;&lt;br /&gt;
import javax.crypto.Cipher;&lt;br /&gt;
import javax.crypto.KeyGenerator;&lt;br /&gt;
import javax.crypto.spec.SecretKeySpec;&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;
    KeyGenerator generator = KeyGenerator.getInstance(&amp;quot;AES&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    generator.init(128);&lt;br /&gt;
    Key keyToBeWrapped = generator.generateKey();&lt;br /&gt;
    System.out.println(&amp;quot;input    : &amp;quot; + new String(keyToBeWrapped.getEncoded()));&lt;br /&gt;
    // create a wrapper and do the wrapping&lt;br /&gt;
    Cipher cipher = Cipher.getInstance(&amp;quot;AES/ECB/NoPadding&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    KeyGenerator keyGen = KeyGenerator.getInstance(&amp;quot;AES&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    keyGen.init(256);&lt;br /&gt;
    Key wrapKey = keyGen.generateKey();&lt;br /&gt;
    cipher.init(Cipher.ENCRYPT_MODE, wrapKey);&lt;br /&gt;
    byte[] wrappedKey = cipher.doFinal(keyToBeWrapped.getEncoded());&lt;br /&gt;
    System.out.println(&amp;quot;wrapped  : &amp;quot; + new String(wrappedKey));&lt;br /&gt;
    // unwrap the wrapped key&lt;br /&gt;
    cipher.init(Cipher.DECRYPT_MODE, wrapKey);&lt;br /&gt;
    Key key = new SecretKeySpec(cipher.doFinal(wrappedKey), &amp;quot;AES&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;unwrapped: &amp;quot; + new String(key.getEncoded()));&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &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>