<?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_Tutorial%2FSecurity%2FPublic_Key_Cryptography_Standards</id>
		<title>Java Tutorial/Security/Public Key Cryptography Standards - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FSecurity%2FPublic_Key_Cryptography_Standards"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Security/Public_Key_Cryptography_Standards&amp;action=history"/>
		<updated>2026-04-21T12:04:58Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java_Tutorial/Security/Public_Key_Cryptography_Standards&amp;diff=4288&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Security/Public_Key_Cryptography_Standards&amp;diff=4288&amp;oldid=prev"/>
				<updated>2010-06-01T05:01:21Z</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:01, 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_Tutorial/Security/Public_Key_Cryptography_Standards&amp;diff=4287&amp;oldid=prev</id>
		<title> в 17:44, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Security/Public_Key_Cryptography_Standards&amp;diff=4287&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;==  Basic class for exploring PKCS #1 V1.5 Signatures. ==&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.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.Signature;&lt;br /&gt;
import javax.crypto.Cipher;&lt;br /&gt;
import org.bouncycastle.asn1.ASN1InputStream;&lt;br /&gt;
import org.bouncycastle.asn1.ASN1OctetString;&lt;br /&gt;
import org.bouncycastle.asn1.ASN1Sequence;&lt;br /&gt;
import org.bouncycastle.asn1.util.ASN1Dump;&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;RSA&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    keyGen.initialize(512, new SecureRandom());&lt;br /&gt;
    KeyPair keyPair = keyGen.generateKeyPair();&lt;br /&gt;
    Signature signature = Signature.getInstance(&amp;quot;SHA256withRSA&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    signature.initSign(keyPair.getPrivate());&lt;br /&gt;
    byte[] message = &amp;quot;abc&amp;quot;.getBytes();&lt;br /&gt;
    signature.update(message);&lt;br /&gt;
    byte[] sigBytes = signature.sign();&lt;br /&gt;
    Cipher cipher = Cipher.getInstance(&amp;quot;RSA/None/PKCS1Padding&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    cipher.init(Cipher.DECRYPT_MODE, keyPair.getPublic());&lt;br /&gt;
    byte[] decSig = cipher.doFinal(sigBytes);&lt;br /&gt;
    ASN1InputStream aIn = new ASN1InputStream(decSig);&lt;br /&gt;
    ASN1Sequence seq = (ASN1Sequence) aIn.readObject();&lt;br /&gt;
    System.out.println(ASN1Dump.dumpAsString(seq));&lt;br /&gt;
    MessageDigest hash = MessageDigest.getInstance(&amp;quot;SHA-256&amp;quot;, &amp;quot;BC&amp;quot;);&lt;br /&gt;
    hash.update(message);&lt;br /&gt;
    ASN1OctetString sigHash = (ASN1OctetString) seq.getObjectAt(1);&lt;br /&gt;
    System.out.println(MessageDigest.isEqual(hash.digest(), sigHash.getOctets()));&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>