C# 3Des ECB加密方式


        /// <summary>
        /// ECB加密
        /// </summary>
        /// <param name="paymentCode">加密字符串</param>
        /// <param name="key">秘钥</param>
        /// <param name="iv">ECB模式不需要IV</param>
        /// <returns></returns>
        public static string DESEncrypt(string paymentCode, string key, string iv = "12345678")
        {
            SymmetricAlgorithm symmetric;
            ICryptoTransform iCrypto;
            MemoryStream memory;
            CryptoStream crypto;
            byte[] byt;
            using (symmetric = new TripleDESCryptoServiceProvider())
            {
                symmetric.Key = Encoding.UTF8.GetBytes(key);
                //symmetric.IV = Encoding.UTF8.GetBytes(iv);
                symmetric.Mode = CipherMode.ECB;
                symmetric.Padding = PaddingMode.PKCS7;


                iCrypto = symmetric.CreateEncryptor();
                byt = Encoding.UTF8.GetBytes(paymentCode);
                memory = new MemoryStream();
                using (crypto = new CryptoStream(memory, iCrypto, CryptoStreamMode.Write))
                {
                    crypto.Write(byt, 0, byt.Length);
                    crypto.FlushFinalBlock();
                    crypto.Close();
                    //return Convert.ToBase64String(memory.ToArray());
                    //return Encoding.UTF8.GetString(memory.ToArray());
                    return Convert.ToBase64String(memory.ToArray());
                }
            }
        }

        /// <summary>
        /// ECB解密
        /// </summary>
        /// <param name="data">解密字符串</param>
        /// <param name="key">秘钥</param>
        /// <param name="iv">ECB模式不需要IV</param>
        /// <returns></returns>
        public static string DESDecrypst(string data, string key, string iv)
        {
            using (SymmetricAlgorithm mCSP = new TripleDESCryptoServiceProvider())
            {
                mCSP.Key = Encoding.UTF8.GetBytes(key);
                //mCSP.IV = Encoding.UTF8.GetBytes(iv);
                mCSP.Mode = CipherMode.ECB;
                mCSP.Padding = PaddingMode.Zeros;

                ICryptoTransform iCrypto;
                MemoryStream memory;
                CryptoStream crypto;
                byte[] byt;
                iCrypto = mCSP.CreateDecryptor(mCSP.Key, mCSP.IV);

                byt = Convert.FromBase64String(data);
                memory = new MemoryStream();
                using (crypto = new CryptoStream(memory, iCrypto, CryptoStreamMode.Write))
                {
                    crypto.Write(byt, 0, byt.Length);
                    crypto.FlushFinalBlock();
                    crypto.Close();
                }
                return Encoding.UTF8.GetString(memory.ToArray());
            }
        }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值