打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
C# 加解密之RSA

    RSA,非对称加密,简单可以理解为现在有两把钥匙,一把只能用来开,一把只能用来关,所以这跟前面写的对称加密是不一样的;

原理和算法的话,不谈。。。还是自己去查吧,费脑子。

主要说下优缺点吧,首先就是RSA的安全性高,嗯,很高,比DES和AES要高很多,但由于密钥长度或者算法复杂度的提高就会带来性能的损失,所以RSA的效率就比较低,所以我们一般不会采用RSA加密一些大的数据,如果非要加密的话,可以采用混合加密,比如DES或者AES来加密数据,用RSA来加密密钥;或者采用分块加密的方式,即只加密其中一部分或者关键部分。

RSA一般公钥用来加密,私钥用来做解密,所以我们这里需要预先生成两把密钥。生成密钥的方式也有很多种,这里就采用最直接的方式了。

实现功能:

    • 使用RSA加密方式加解密文本数据

开发环境:

开发工具:Visual Studio 2013

.NET Framework版本:4.5

实现代码:

  /// <summary>        /// 生成公钥和私钥        /// </summary>        /// <returns></returns>        public static RsaKey CreateKey()        {            RSACryptoServiceProvider rsaProvider = new RSACryptoServiceProvider();            RsaKey rsaKey = new RsaKey();
rsaKey.PublicKey=rsaProvider.ToXmlString(false); rsaKey.PrivateKey = rsaProvider.ToXmlString(true); return rsaKey; }
/// <summary> /// RSA加密 /// </summary> /// <param name="rsaModel"></param> /// <returns></returns> 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; }
/// <summary> /// RSA解密 /// </summary> /// <param name="rsaModel"></param> /// <returns></returns> 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; }
/// <summary> /// RSA加密字符串 /// </summary> /// <param name="data">要加密的字符串</param> /// <param name="key">公钥</param> /// <returns></returns> 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); }
/// <summary> /// RSA解密字符串 /// </summary> /// <param name="data">要解密的字符串</param> /// <param name="key">私钥</param> /// <returns></returns> 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 { /// <summary> /// 公钥 /// </summary> public string PublicKey { get; set; }
/// <summary> /// 私钥 /// </summary> public string PrivateKey { get; set; } }
public class RsaModel { /// <summary> /// 需要加密/解密的数据 /// </summary> public byte[] Data { get; set; }
/// <summary> /// 密钥(加密:公钥;解密:私钥) /// </summary> 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; }

实现效果:

由简入繁,拿来即用

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
RSA加密解密及数字签名Java实现
非对称加密RSA的应用及在C#中的实现
使用RSA进行信息加密解密的WebService示例
C#中RSA加密解密和签名与验证的实现
C#里的一些加密解密标准函数示例——DES,SHA1,RSA
C#编程总结(七)数据加密——附源码
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服