使用对称加密、解密

#region 使用对称加密、解密

        /// <summary>         /// 使用对称算法加密         /// </summary>         /// <param name="str"></param>         /// <param name="encryptKey"></param>         /// <returns></returns>          public static string SymmetricEncrypts(string str, string encryptKey)         {             string result = string.Empty;             byte[] inputData = System.Text.Encoding.UTF8.GetBytes(str);             byte[] IV = { 0x77, 0x70, 0x50, 0xD9, 0xE1, 0x7F, 0x23, 0x13, 0x7A, 0xB3, 0xC7, 0xA7, 0x48, 0x2A, 0x4B, 0x39 };             try             {                 byte[] byKey = System.Text.Encoding.UTF8.GetBytes(encryptKey);                 //如需指定加密算法,可在Create()参数中指定字符串                 //Create()方法中的参数可以是:DES、RC2 System、Rijndael、TripleDES                 //采用不同的实现类对IV向量的要求不一样(可以用GenerateIV()方法生成),无参数表示用Rijndael                  SymmetricAlgorithm Algorithm = SymmetricAlgorithm.Create();//产生一种加密算法                  MemoryStream msTarget = new MemoryStream();                 //定义将数据流链接到加密转换的流。                  CryptoStream encStream = new CryptoStream(msTarget, Algorithm.CreateEncryptor(byKey, IV), CryptoStreamMode.Write);                 encStream.Write(inputData, 0, inputData.Length);                 encStream.FlushFinalBlock();                 result = Convert.ToBase64String(msTarget.ToArray());             }             catch (Exception)             {                 return null;             }             return result;         }

        /// <summary>         /// 使用对称算法解密         /// </summary>         /// <param name="encryptStr"></param>         /// <param name="encryptKey"></param>         /// <returns></returns>          public static string SymmectricDecrypts(string encryptStr, string encryptKey)         {             string result = string.Empty;             //加密时使用的是Convert.ToBase64String(),解密时必须使用Convert.FromBase64String()              try             {                 byte[] encryptData = Convert.FromBase64String(encryptStr);                 byte[] byKey = System.Text.Encoding.UTF8.GetBytes(encryptKey);                 byte[] IV = { 0x77, 0x70, 0x50, 0xD9, 0xE1, 0x7F, 0x23, 0x13, 0x7A, 0xB3, 0xC7, 0xA7, 0x48, 0x2A, 0x4B, 0x39 };                 SymmetricAlgorithm Algorithm = SymmetricAlgorithm.Create();                 MemoryStream msTarget = new MemoryStream();                 CryptoStream decStream = new CryptoStream(msTarget, Algorithm.CreateDecryptor(byKey, IV), CryptoStreamMode.Write);                 decStream.Write(encryptData, 0, encryptData.Length);                 decStream.FlushFinalBlock();                 result = System.Text.Encoding.Default.GetString(msTarget.ToArray());             }             catch (Exception)             {                 return null;             }             return result;         }

        #endregion

转载于:https://www.cnblogs.com/wlzhang/p/3504923.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值