<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FSecurity%2FRSA</id>
		<title>Csharp/CSharp Tutorial/Security/RSA - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FSecurity%2FRSA"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Security/RSA&amp;action=history"/>
		<updated>2026-04-30T04:03:38Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Security/RSA&amp;diff=6032&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Security/RSA&amp;diff=6032&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:53Z</updated>
		
		<summary type="html">&lt;p&gt;&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;Версия 15:31, 26 мая 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>
			</entry>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Security/RSA&amp;diff=6033&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/Security/RSA&amp;diff=6033&amp;oldid=prev"/>
				<updated>2010-05-26T12:17:57Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Asymmetric cryptography==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Security.Cryptography;&lt;br /&gt;
class MainClass&lt;br /&gt;
{&lt;br /&gt;
  public static void Main() &lt;br /&gt;
  {&lt;br /&gt;
    RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();&lt;br /&gt;
    Byte[] testData = {1, 2, 3, 4, 5, 6, 7, 8};&lt;br /&gt;
    Byte[] encryptedData = rsa.Encrypt(testData, false);&lt;br /&gt;
    Console.WriteLine(&amp;quot;Encrypted data:&amp;quot;);&lt;br /&gt;
    for(int i=0; i&amp;lt;encryptedData.GetLength(0); i++)&lt;br /&gt;
    {&lt;br /&gt;
      Console.Write(&amp;quot;{0} &amp;quot;, encryptedData[i]);&lt;br /&gt;
    }&lt;br /&gt;
    Byte[] decryptedData = rsa.Decrypt(encryptedData, false);&lt;br /&gt;
    Console.WriteLine(&amp;quot;Decrypted Data:&amp;quot;);&lt;br /&gt;
    for(int i=0; i&amp;lt;decryptedData.GetLength(0); i++)&lt;br /&gt;
    {&lt;br /&gt;
      Console.Write(&amp;quot;{0} &amp;quot;, decryptedData[i]);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;Encrypted data:&lt;br /&gt;
105 216 155 138 34 149 122 27 220 172 6 69 23 21 224 142 30 166 81 141 15 234 144 235 122 187 99 245&lt;br /&gt;
 222 252 154 234 211 79 251 80 253 221 94 91 222 86 225 17 0 96 161 179 155 251 123 140 38 6 161 78&lt;br /&gt;
111 193 19 222 251 74 172 104 100 61 39 106 113 67 69 45 237 47 194 189 62 168 98 230 196 149 249 11&lt;br /&gt;
3 29 19 66 10 84 73 110 142 142 255 120 138 200 207 79 190 151 164 53 4 198 254 78 203 86 102 233 10&lt;br /&gt;
7 216 13 41 166 125 155 58 48 214 27 116 93 211 176 191 183 Decrypted Data:&lt;br /&gt;
1 2 3 4 5 6 7 8&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Encrypt with RSACryptoServiceProvider==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Security;&lt;br /&gt;
using System.Security.Cryptography;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();&lt;br /&gt;
            StreamReader sr = File.OpenText(&amp;quot;myKey.xml&amp;quot;);&lt;br /&gt;
            string rsaXml = sr.ReadToEnd();&lt;br /&gt;
            sr.Close();&lt;br /&gt;
            rsa.FromXmlString(rsaXml);&lt;br /&gt;
            string messageToJane = &amp;quot;this is a test&amp;quot;;&lt;br /&gt;
            byte[] encrypted = rsa.Encrypt(System.Text.ASCIIEncoding.ASCII.GetBytes(messageToJane), false);&lt;br /&gt;
            FileStream fs = new FileStream(&amp;quot;Message.dat&amp;quot;, FileMode.Create);&lt;br /&gt;
            fs.Write(encrypted, 0, encrypted.Length);&lt;br /&gt;
            fs.Close();&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==RSACryptoServiceProvider reads from xml key==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Security;&lt;br /&gt;
using System.Security.Cryptography;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            StreamReader sr = File.OpenText(&amp;quot;myKey.xml&amp;quot;);&lt;br /&gt;
            string myKey = sr.ReadToEnd();&lt;br /&gt;
            sr.Close();&lt;br /&gt;
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();&lt;br /&gt;
            rsa.FromXmlString(myKey);&lt;br /&gt;
            FileStream fs = new FileStream(&amp;quot;Message.dat&amp;quot;, FileMode.Open);&lt;br /&gt;
            byte[] encrypted = new byte[fs.Length];&lt;br /&gt;
            fs.Read(encrypted, 0, (int)fs.Length);&lt;br /&gt;
            byte[] decrypted = rsa.Decrypt(encrypted, false);&lt;br /&gt;
            fs.Close();&lt;br /&gt;
            Console.WriteLine(System.Text.ASCIIEncoding.ASCII.GetString(decrypted));&lt;br /&gt;
            &lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Using RSACryptoServiceProvider==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Security.Cryptography;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            string verifiableMesage = &amp;quot;this is a test&amp;quot;;&lt;br /&gt;
            SHA1Managed sha = new SHA1Managed();&lt;br /&gt;
            byte[] hashValue = sha.ruputeHash(System.Text.ASCIIEncoding.ASCII.GetBytes(verifiableMesage));&lt;br /&gt;
            StreamReader sr = File.OpenText(&amp;quot;Key.xml&amp;quot;);&lt;br /&gt;
            string myKey = sr.ReadToEnd();&lt;br /&gt;
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();&lt;br /&gt;
            rsa.FromXmlString(myKey);&lt;br /&gt;
            RSAPKCS1SignatureFormatter sigFormatter = new RSAPKCS1SignatureFormatter(rsa);&lt;br /&gt;
            sigFormatter.SetHashAlgorithm(&amp;quot;SHA1&amp;quot;);&lt;br /&gt;
            byte[] signedHash = sigFormatter.CreateSignature(hashValue);&lt;br /&gt;
            FileStream fs = new FileStream(&amp;quot;signedHash.dat&amp;quot;, FileMode.Create);&lt;br /&gt;
            fs.Write(signedHash, 0, signedHash.Length);&lt;br /&gt;
            fs.Close();&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Using RSAPKCS1SignatureDeformatter==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Security;&lt;br /&gt;
using System.Security.Cryptography;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            string verifiableMesage = &amp;quot;this is a test&amp;quot;;&lt;br /&gt;
            string     wrongMessage = &amp;quot;this is another test&amp;quot;;&lt;br /&gt;
            SHA1Managed sha = new SHA1Managed();&lt;br /&gt;
            byte[] verifiableMessageHash = sha.ruputeHash(System.Text.ASCIIEncoding.ASCII.GetBytes(verifiableMesage));&lt;br /&gt;
            byte[] wrongMessageHash = sha.ruputeHash(System.Text.ASCIIEncoding.ASCII.GetBytes(wrongMessage));&lt;br /&gt;
            FileStream fs = new FileStream(&amp;quot;signedHash.dat&amp;quot;, FileMode.Open);&lt;br /&gt;
            byte[] fileHash = new byte[fs.Length];&lt;br /&gt;
            fs.Read(fileHash, 0, (int)fs.Length);&lt;br /&gt;
            fs.Close();&lt;br /&gt;
            StreamReader sr = File.OpenText(&amp;quot;myKey.xml&amp;quot;);&lt;br /&gt;
            string myKey = sr.ReadToEnd();&lt;br /&gt;
            sr.Close();&lt;br /&gt;
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();&lt;br /&gt;
            rsa.FromXmlString(myKey);&lt;br /&gt;
            RSAPKCS1SignatureDeformatter sigDeformatter = new RSAPKCS1SignatureDeformatter(rsa);&lt;br /&gt;
            sigDeformatter.SetHashAlgorithm(&amp;quot;SHA1&amp;quot;);&lt;br /&gt;
            Console.WriteLine(sigDeformatter.VerifySignature(verifiableMessageHash, fileHash));&lt;br /&gt;
            Console.WriteLine(sigDeformatter.VerifySignature(wrongMessageHash, fileHash) == false);&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>