私は公開鍵/秘密鍵の手法を使ってデータを暗号化したいと思っています。つまり、受信者の公開鍵で暗号化し、受信者は自分の秘密鍵で復号化することができます。C#での公開鍵暗号化と秘密鍵暗号化の使い方
どうすればいいですか?提案やサンプルコードなどがありますか?
私は公開鍵/秘密鍵の手法を使ってデータを暗号化したいと思っています。つまり、受信者の公開鍵で暗号化し、受信者は自分の秘密鍵で復号化することができます。C#での公開鍵暗号化と秘密鍵暗号化の使い方
どうすればいいですか?提案やサンプルコードなどがありますか?
コード例:
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();
}
RSACryptoServiceProviderが意図されていませんデータの暗号化されたランダムなブロブ(データサイズはキーサイズに制限されています)。一般に、OAEPパッディングを使用して、選択された暗号テキスト攻撃から保護するためにPCKS1v1.5を明示的に切り替える必要はありません。誰もこのサンプルコードを使用しないでください。 – jbtule
@ jbtule:プライベート&パブリックキーのコンセプトで大きなデータを暗号化するのに最適な方法を教えてください。 – Mou
@Mou私が集めたものから、対称鍵を生成し、これを受信者の公開鍵で暗号化して送信します。レシーバーはそれを自分の秘密鍵で復号化し、共有データで暗号化した大きなデータを共有します。 n回の送信ごとに対称鍵を更新することができます。私はこれがSSLの仕組みだと思う(私はそれが非常に簡単な説明だと確信している) – MikeJansen
[あなたは何を試してみました?](http://mattgemmell.com/2008/12/08/what-have-you-tried/) – ntoskrnl