15

私は公開鍵/秘密鍵の手法を使ってデータを暗号化したいと思っています。つまり、受信者の公開鍵で暗号化し、受信者は自分の秘密鍵で復号化することができます。C#での公開鍵暗号化と秘密鍵暗号化の使い方

どうすればいいですか?提案やサンプルコードなどがありますか?

+3

[あなたは何を試してみました?](http://mattgemmell.com/2008/12/08/what-have-you-tried/) – ntoskrnl

答えて

21

コード例:

private static string _privateKey; 
private static string _publicKey; 
private static UnicodeEncoding _encoder = new UnicodeEncoding(); 

private static void RSA() 
{ 
    var rsa = new RSACryptoServiceProvider(); 
    _privateKey = rsa.ToXmlString(true); 
    _publicKey = rsa.ToXmlString(false); 

    var text = "Test1"; 
    Console.WriteLine("RSA // Text to encrypt: " + text); 
    var enc = Encrypt(text); 
    Console.WriteLine("RSA // Encrypted Text: " + enc); 
    var dec = Decrypt(enc); 
    Console.WriteLine("RSA // Decrypted Text: " + dec); 
} 

public static string Decrypt(string data) 
{ 
    var rsa = new RSACryptoServiceProvider(); 
    var dataArray = data.Split(new char[] { ',' }); 
    byte[] dataByte = new byte[dataArray.Length]; 
    for (int i = 0; i < dataArray.Length; i++) 
    { 
    dataByte[i] = Convert.ToByte(dataArray[i]); 
    } 

    rsa.FromXmlString(_privateKey); 
    var decryptedByte = rsa.Decrypt(dataByte, false); 
    return _encoder.GetString(decryptedByte); 
} 

public static string Encrypt(string data) 
{ 
    var rsa = new RSACryptoServiceProvider(); 
    rsa.FromXmlString(_publicKey); 
    var dataToEncrypt = _encoder.GetBytes(data); 
    var encryptedByteArray = rsa.Encrypt(dataToEncrypt, false).ToArray(); 
    var length = encryptedByteArray.Count(); 
    var item = 0; 
    var sb = new StringBuilder(); 
    foreach (var x in encryptedByteArray) 
    { 
    item++; 
    sb.Append(x); 

    if (item < length) 
     sb.Append(","); 
    } 

    return sb.ToString(); 
} 
+12

RSACryptoServiceProviderが意図されていませんデータの暗号化されたランダムなブロブ(データサイズはキーサイズに制限されています)。一般に、OAEPパッディングを使用して、選択された暗号テキスト攻撃から保護するためにPCKS1v1.5を明示的に切り替える必要はありません。誰もこのサンプルコードを使用しないでください。 – jbtule

+9

@ jbtule:プライベート&パブリックキーのコンセプトで大きなデータを暗号化するのに最適な方法を教えてください。 – Mou

+0

@Mou私が集めたものから、対称鍵を生成し、これを受信者の公開鍵で暗号化して送信します。レシーバーはそれを自分の秘密鍵で復号化し、共有データで暗号化した大きなデータを共有します。 n回の送信ごとに対称鍵を更新することができます。私はこれがSSLの仕組みだと思う(私はそれが非常に簡単な説明だと確信している) – MikeJansen

関連する問題