RijndaelManaged 加密

 public  string Encrypt(string str)
        {
            string result = null;
            if (str == null)
            {
                return result;
            }
            try
            {
                byte[] array0 = Encoding.ASCII.GetBytes(str);
                MemoryStream stream = new MemoryStream(array0);
                RijndaelManaged rijndaelManaged = new RijndaelManaged();
                byte[] key = new byte[32] { 5, 1, 3, 28, 27, 3, 2, 16, 12, 19, 39, 200, 10, 18, 181, 79, 103, 61, 145, 215, 125, 212, 131, 241, 229, 254, 250, 205, 11, 29, 83, 125 };
                byte[] vi = new byte[16] { 204, 19, 18, 10, 147, 108, 20, 177, 26, 171, 19, 143, 38, 112, 19, 12 };

                ICryptoTransform transform = rijndaelManaged.CreateEncryptor(key, vi);
                CryptoStream cryptoStream = new CryptoStream(stream, transform, CryptoStreamMode.Write);
                result = cryptoStream.ToString();
                cryptoStream.FlushFinalBlock();
                return result;
            }
            catch
            {
                return null;
            }
        }

        public  string Decode(string str)
        {
            string result = null;
            if (str == null)
            {
                return result;
            }

            try
            {
                byte[] array0 = Encoding.ASCII.GetBytes(str);
                MemoryStream stream = new MemoryStream(array0);
                RijndaelManaged rijndaelManaged = new RijndaelManaged();
                byte[] key = new byte[32] { 5, 1, 3, 28, 27, 3, 2, 16, 12, 19, 39, 200, 10, 18, 181, 79, 103, 61, 145, 215, 125, 212, 131, 241, 229, 254, 250, 205, 11, 29, 83, 125 };
                byte[] vi = new byte[16] { 204, 19, 18, 10, 147, 108, 20, 177, 26, 171, 19, 143, 38, 112, 19, 12 };

                ICryptoTransform transform = rijndaelManaged.CreateEncryptor(key, vi);
                CryptoStream inStream = new CryptoStream(stream, transform, CryptoStreamMode.Read);
                return inStream.ToString();
            }
            catch
            {
                return null;
            }
        }

1.代码中key和vi分别对应加密器对象Key和初始化向量 (IV)

2.Key和VI只有完全匹配得上加密数据才可以被解密

转载于:https://www.cnblogs.com/Khan-Sadas/p/11058233.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值