• 非对称可逆加密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!");
            }
  • 相关阅读:
    [译]JavaScript源码转换:非破坏式与再生式
    [译]ES6中的代理对象
    tensorflow 如何获取graph中的所有tensor name
    python3中的str和bytes
    git submodule 添加 更新 删除 教程
    《重构:改善既有代码的设计》摘抄
    thrift入门教程/thrift资料集合
    将python2代码升级为python3代码最佳实践
    python标准库:subprocess——子进程管理
    安装“python-snappy”遇到“error: command 'x86_64-linux-gnu-gcc' failed with exit status 1”
  • 原文地址:https://www.cnblogs.com/zhangnever/p/12427564.html
Copyright © 2020-2023  润新知