zoukankan      html  css  js  c++  java
  • 非对称可逆加密RSA

    加密key与解密key不是一个,而是一对

    加密key与解密key是不能互相推导的,有密文,没有解密key也推导不出来原文

    加密解密速度慢,但是安全性好

    特点:

    公开解密key,保证数据的安全传递

    公开机密key,保证数据的不可抵赖

    code:

            /// <summary>
            /// 获取非对称的这对密钥
            /// </summary>
            /// <returns></returns>
            public static KeyValuePair<string, string> GetKeyPair()
            {
                RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
                return new KeyValuePair<string, string>(RSA.ToXmlString(false), RSA.ToXmlString(true));
            }
    
            /// <summary>
            /// 加密
            /// </summary>
            /// <param name="content">内容</param>
            /// <param name="key">密钥</param>
            /// <returns></returns>
            public static string Encrypt(string content, string key)
            {
                RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
                RSA.FromXmlString(key);
                UnicodeEncoding unicodeEncoding = new UnicodeEncoding();
                byte[] DataToEncrypt = unicodeEncoding.GetBytes(content);
                byte[] resultBytes = RSA.Encrypt(DataToEncrypt, false);
                return Convert.ToBase64String(resultBytes);
            }
    
            /// <summary>
            /// 解密  内容加解密key
            /// </summary>
            /// <param name="content"></param>
            /// <param name="key"></param>
            /// <returns></returns>
            public static string Decryp(string content, string key)
            {
                byte[] DataToEncrypt = Convert.FromBase64String(content);
                RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
                RSA.FromXmlString(key);
                byte[] resultBytes = RSA.Decrypt(DataToEncrypt, false);
                return Encoding.UTF8.GetString(resultBytes);
            }
            static void Main(string[] args)
            {
                //获得加密解密键值对
                KeyValuePair<string, string> keyValuePair = ReaEncrypt.GetKeyPair();
                //加密
                string rsaEnl = ReaEncrypt.Encrypt("ok", keyValuePair.Key);
                //解密
                string rsadDel = ReaEncrypt.Decryp(rsaEnl, keyValuePair.Value);
                Console.WriteLine("Hello World!");
            }
  • 相关阅读:
    sql server 获取存储过程,表值,标量函数的参数
    拼接枚举字符串
    存储过程的输出接受强类
    映射对象
    C# abstract,virtual 修饰符
    SqlSugar之SqlQueryDynamic返回值处理
    sql server 中数据库数据导入到另一个库中
    sql server 自增长显式添加值
    sql得到表中的列信息
    程序中MMap集合数据重复导致程序慢的情况
  • 原文地址:https://www.cnblogs.com/zhangnever/p/12427564.html
Copyright © 2011-2022 走看看