C# 加解密之RSA
|
admin
2023年2月27日 10:27
本文热度 631
|
RSA,非对称加密,简单可以理解为现在有两把钥匙,一把只能用来开,一把只能用来关,所以这跟前面写的对称加密是不一样的;
原理和算法的话,不谈。。。还是自己去查吧,费脑子。
主要说下优缺点吧,首先就是RSA的安全性高,嗯,很高,比DES和AES要高很多,但由于密钥长度或者算法复杂度的提高就会带来性能的损失,所以RSA的效率就比较低,所以我们一般不会采用RSA加密一些大的数据,如果非要加密的话,可以采用混合加密,比如DES或者AES来加密数据,用RSA来加密密钥;或者采用分块加密的方式,即只加密其中一部分或者关键部分。
RSA一般公钥用来加密,私钥用来做解密,所以我们这里需要预先生成两把密钥。生成密钥的方式也有很多种,这里就采用最直接的方式了。
实现功能:
开发环境:
开发工具:Visual Studio 2013
.NET Framework版本:4.5
实现代码:
public static RsaKey createKey()
{
RSACryptoServiceProvider rsaProvider = new RSACryptoServiceProvider();
RsaKey rsaKey = new RsaKey();
rsaKey.PublicKey=rsaProvider.ToXmlString(false);
rsaKey.PrivateKey = rsaProvider.ToXmlString(true);
return rsaKey;
}
public static byte[] Encrypt(RsaModel rsaModel)
{
RSACryptoServiceProvider rsaProvider = new RSACryptoServiceProvider();
byte[] result = null;
try
{
rsaProvider.fromXmlString(rsaModel.Key);
result = rsaProvider.Encrypt(rsaModel.Data, false);
}
catch { }
return result;
}
public static byte[] Decrypt(RsaModel rsaModel)
{
RSACryptoServiceProvider rsaProvider = new RSACryptoServiceProvider();
byte[] result = null;
try
{
rsaProvider.fromXmlString(rsaModel.Key);
result = rsaProvider.Decrypt(rsaModel.Data, false);
}
catch { }
return result;
}
public static string Encrypt(string data, string key)
{
byte[] bytes = Encoding.UTF8.GetBytes(data);
byte[] result = Encrypt(new RsaModel
{
Data = bytes,
Key = key
});
if (result == null)
{
return "";
}
return Convert.ToBase64String(result);
}
public static string Decrypt(string data, string key)
{
byte[] bytes = Convert.fromBase64String(data);
byte[] result = Decrypt(new RsaModel
{
Data = bytes,
Key = key
});
if (result == null)
{
return "";
}
return Encoding.UTF8.GetString(result);
}
public class RsaKey
{
public string PublicKey { get; set; }
public string PrivateKey { get; set; }
}
public class RsaModel
{
public byte[] Data { get; set; }
public string Key { get; set; }
}
RsaUtil.RsaKey rsaKey = new RsaUtil.RsaKey();
private void btn_Rsa_Encrypt_Click(object sender, EventArgs e)
{
rsaKey = RsaUtil.createKey();
string result = RsaUtil.Encrypt(textBox1.Text, rsaKey.PublicKey);
textBox2.Text = result;
}
private void btn_Rsa_Decrypt_Click(object sender, EventArgs e)
{
string result = RsaUtil.Decrypt(textBox2.Text, rsaKey.PrivateKey);
textBox1.Text = result;
}
实现效果:
该文章在 2023/2/27 10:27:27 编辑过