zoukankan      html  css  js  c++  java
  • [C#]AES加解密

    using System;
    using System.IO;
    using System.Security.Cryptography;
    using System.Text;
    
    namespace Utils
    {
        /// <summary>
        /// CommonTools加密解密
        /// </summary>
        public class CommonTools
        {
            #region 加密
    
            static byte[] m_btIV = Convert.FromBase64String("T1hYc1BlM2hmaTVocVJLV3JOMlRrS3A4CiA=");
            static byte[] m_salt = Convert.FromBase64String("OWYya1BuMnl2SEhuQmxZUGpJRmJGMmRLOUpKTVZyOU5iR1A1RzdzZTdqWnl4WDJpc09SeFJSdzZCUjM4bHFkUQog");
    
            #region 加密字符串
            /// <summary>
            /// CommonTools 加密
            /// </summary>
            /// <param name="encryptString">待加密密文</param>
            /// <param name="encryptKey">加密密钥</param>
            /// <param name="encoding">编码</param>
    
    
            public static string AESEncrypt(string encryptString, string encryptKey, Encoding encoding)
            {
                if (encoding is null)
                {
                    encoding = Encoding.UTF8;
                }
                return Convert.ToBase64String(AESEncrypt(encoding.GetBytes(encryptString), encryptKey));
            }
            #endregion
    
            #region 加密字节数组
            /// <summary>
            /// CommonTools 加密
            /// </summary>
            /// <param name="EncryptByte">待加密密文</param>
            /// <param name="encryptKey">加密密钥</param>
            public static byte[] AESEncrypt(byte[] EncryptByte, string encryptKey)
            {
                if (EncryptByte.Length == 0) { throw (new Exception("明文不得为空")); }
                if (string.IsNullOrEmpty(encryptKey)) { throw (new Exception("密钥不得为空")); }
                byte[] m_strEncrypt;
                byte[] iv = new byte[16];
                Array.Copy(m_btIV, iv, 16);
    
    
                RijndaelManaged m_AESProvider = new RijndaelManaged
                {
                    // Key = keyArray,
                    // IV = iv,
                    Mode = CipherMode.CBC,
                    Padding = PaddingMode.PKCS7,
                    BlockSize = 128
                };
                // Rijndael m_AESProvider = Rijndael.Create();
                try
                {
                    MemoryStream m_stream = new MemoryStream();
                    PasswordDeriveBytes pdb = new PasswordDeriveBytes(encryptKey, m_salt);
                    ICryptoTransform transform = m_AESProvider.CreateEncryptor(pdb.GetBytes(32), iv);
                    CryptoStream m_csstream = new CryptoStream(m_stream, transform, CryptoStreamMode.Write);
                    m_csstream.Write(EncryptByte, 0, EncryptByte.Length);
                    m_csstream.FlushFinalBlock();
                    m_strEncrypt = m_stream.ToArray();
                    m_stream.Close(); m_stream.Dispose();
                    m_csstream.Close(); m_csstream.Dispose();
                }
                catch (IOException ex) { throw ex; }
                catch (CryptographicException ex) { throw ex; }
                catch (ArgumentException ex) { throw ex; }
                catch (Exception ex) { throw ex; }
                finally { m_AESProvider.Clear(); }
                return m_strEncrypt;
            }
            #endregion
            #endregion
    
            #region 解密
            #region 解密字符串
            /// <summary>
            /// CommonTools 解密
            /// </summary>
            /// <param name="decryptString">待解密密文</param>
            /// <param name="decryptKey">解密密钥</param>
            /// <param name="encoding">编码</param>
            public static string AESDecrypt(string decryptString, string decryptKey, Encoding encoding)
            {
                if (encoding is null)
                {
                    encoding = Encoding.UTF8;
                }
                return Convert.ToBase64String(AESDecrypt(encoding.GetBytes(decryptString), decryptKey));
            }
            #endregion
    
            #region 解密字节数组
            /// <summary>
            /// CommonTools 解密
            /// </summary>
            /// <param name="decryptString">待解密密文</param>
            /// <param name="decryptKey">解密密钥</param>
            public static byte[] AESDecrypt(byte[] DecryptByte, string decryptKey)
            {
                if (DecryptByte.Length == 0) { throw (new Exception("密文不得为空")); }
                if (string.IsNullOrEmpty(decryptKey)) { throw (new Exception("密钥不得为空")); }
                byte[] m_strDecrypt;
                byte[] iv = new byte[16];
                Array.Copy(m_btIV, iv, 16);
    
                // Rijndael m_AESProvider = Rijndael.Create();
                RijndaelManaged m_AESProvider = new RijndaelManaged
                {
                    // Key = keyArray,
                    // IV = iv,
                    Mode = CipherMode.CBC,
                    Padding = PaddingMode.PKCS7,
                    BlockSize = 128
                };
    
                try
                {
                    MemoryStream m_stream = new MemoryStream();
                    PasswordDeriveBytes pdb = new PasswordDeriveBytes(decryptKey, m_salt);
                    ICryptoTransform transform = m_AESProvider.CreateDecryptor(pdb.GetBytes(32), iv);
                    CryptoStream m_csstream = new CryptoStream(m_stream, transform, CryptoStreamMode.Write);
                    m_csstream.Write(DecryptByte, 0, DecryptByte.Length);
                    m_csstream.FlushFinalBlock();
                    m_strDecrypt = m_stream.ToArray();
                    m_stream.Close(); m_stream.Dispose();
                    m_csstream.Close(); m_csstream.Dispose();
                }
                catch (IOException ex) { throw ex; }
                catch (CryptographicException ex) { throw ex; }
                catch (ArgumentException ex) { throw ex; }
                catch (Exception ex) { throw ex; }
                finally { m_AESProvider.Clear(); }
                return m_strDecrypt;
            }
    
            public static byte[] SHA256(string str)
            {
                byte[] SHA256Data = Encoding.UTF8.GetBytes(str);
                SHA256Managed Sha256 = new SHA256Managed();
                byte[] by = Sha256.ComputeHash(SHA256Data);
                return by;
            }
    
            public static string Md5String(string str)
            {
                MD5 md5 = MD5.Create();
                // 将字符串转换成字节数组
                byte[] byteOld = Encoding.UTF8.GetBytes(str);
                // 调用加密方法
                byte[] byteNew = md5.ComputeHash(byteOld);
                // 将加密结果转换为字符串
                StringBuilder sb = new StringBuilder();
                foreach (byte b in byteNew)
                {
                    // 将字节转换成16进制表示的字符串,
                    sb.Append(b.ToString("x2"));
                }
                // 返回加密的字符串
                return sb.ToString();
            }
            #endregion
            #endregion
    
        }
    }

  • 相关阅读:
    如何让在JAVA中定义常量池
    java常量池概念
    Efficient Counter in Java
    看到关于JS线程的两篇文章
    Java Collection
    java学习书籍介绍--csdn上一位前辈介绍
    myeclipse快捷键
    数组
    错误处理和时间函数
    函数01
  • 原文地址:https://www.cnblogs.com/linn/p/12572902.html
Copyright © 2011-2022 走看看