c#加密算法

#region DESEnCode DES加密
         ///   <summary>
        
///  默认Key
        
///   </summary>
         private  const  string Default_Key =  " A3F2DEI569WBCJSJEOTY45DYQWF68H1Y ";
         ///   <summary>
        
///  默认IV 矢量,矢量可以为空 
        
///   </summary>
         private  const  string Default_IV =  " qcDX+Y6aPLw= ";
         ///   <summary>
        
///  加密字符串
        
///   </summary>
        
///   <param name="value"></param>
        
///   <returns></returns>
         public  static  string EncryptString( string value)
        {
             return EncryptString(Default_Key, Default_IV, value);
        }
         ///   <summary>
        
///  加密字符串
        
///   </summary>
        
///   <param name="key"> Key键 </param>
        
///   <param name="iv"> 向量 </param>
        
///   <param name="value"> 要加密的串 </param>
        
///   <returns> 加密后的字串 </returns>
         public  static  string EncryptString( string key,  string iv,  string value)
        {
             using (SymmetricAlgorithm desCSP =  new TripleDESCryptoServiceProvider())
            {
                desCSP.Key = Convert.FromBase64String(key);
                desCSP.IV = Convert.FromBase64String(iv);     // 指定加密的运算模式 
                desCSP.Mode = System.Security.Cryptography.CipherMode.ECB;     // 获取或设置加密算法的填充模式 
                desCSP.Padding = System.Security.Cryptography.PaddingMode.PKCS7;
                ICryptoTransform ctTrans = desCSP.CreateEncryptor(desCSP.Key, desCSP.IV);
                 byte[] bytes = Encoding.UTF8.GetBytes(value);
                 using (MemoryStream memStream =  new MemoryStream())
                {
                     using (CryptoStream csEncrypt =  new CryptoStream(memStream, ctTrans, CryptoStreamMode.Write))
                    {
                        csEncrypt.Write(bytes,  0, bytes.Length);
                        csEncrypt.FlushFinalBlock();
                        csEncrypt.Close();
                    }
                    bytes =  null// 清理内存
                     return Convert.ToBase64String(memStream.ToArray());
                }
            }
        }
         ///   <summary>
        
///  解密字符串
        
///   </summary>
        
///   <param name="value"></param>
        
///   <returns></returns>
         public  static  string DecryptString( string value)
        {
             return DecryptString(Default_Key, Default_IV, value);
        }
         ///   <summary>
        
///  解密字符串
        
///   </summary>
        
///   <param name="key"> Key键 </param>
        
///   <param name="iv"> 向量 </param>
        
///   <param name="value"> 要解密的串 </param>
        
///   <returns> 解密后的字串 </returns>
         public  static  string DecryptString( string key,  string iv,  string value)
        {
             using (SymmetricAlgorithm desCSP =  new TripleDESCryptoServiceProvider())
            {
                desCSP.Key = Convert.FromBase64String(key);
                desCSP.IV = Convert.FromBase64String(iv);     // 指定加密的运算模式 
                desCSP.Mode = System.Security.Cryptography.CipherMode.ECB;     // 获取或设置加密算法的填充模式 
                desCSP.Padding = System.Security.Cryptography.PaddingMode.PKCS7;
                ICryptoTransform ctTrans = desCSP.CreateDecryptor(desCSP.Key, desCSP.IV);
                 byte[] bytes = Convert.FromBase64String(value);
                 byte[] bytesOut =  new  byte[ 10240];
                 int iReadLen =  0;
                 using (MemoryStream memStream =  new MemoryStream(bytes))
                {
                     using (CryptoStream csDecrypt =  new CryptoStream(memStream, ctTrans, CryptoStreamMode.Read))
                    {
                         using (MemoryStream outStream =  new MemoryStream())
                        {
                             while ((iReadLen = csDecrypt.Read(bytesOut,  0, bytesOut.Length)) >  0)
                            {
                                outStream.Write(bytesOut,  0, iReadLen);
                            }
                            bytes =  null;
                            bytesOut =  null; // 清理内存
                             return System.Text.Encoding.UTF8.GetString(outStream.ToArray());
                        }
                    }
                }
            }
        }
         #endregion
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值