CryptoJS 、C#互通加解密(AES版)

///////////////////////////////////////前端代码///////////////////////////////////////
@{
ViewBag.Title = "Login";
Layout = null;
}


  

///////////////////////////////////////后台代码///////////////////////////////////////
 public class CryptoJSController : Controller
    {

        public ActionResult Login()
        {
            ViewBag.AESKey = Session["AESKey"] = LoginCryptoHelper.GetAesKey();
            return View();
        }

        [HttpPost]
        public ActionResult Login(string userId, string passWord)
        {
            string AesKey = Session["AESKey"] as string;
            string content = string.Format("DuserId:{0},DpassWord:{1}", LoginCryptoHelper.DecryptByAES(userId, AesKey), LoginCryptoHelper.DecryptByAES(passWord, AesKey));
            return Content(content); 
        }  
    }

    public static class LoginCryptoHelper
    {

        const string IV = "1234567890000000"; 

        /// 
        ///  获取Aes32位密钥
        /// 
        /// 
        public static string GetAesKey()
        {
            string key = Convert.ToString(Guid.NewGuid());
            if (key.Length < 32)
            {
                // 不足32补全
                key = key.PadRight(32, '0');
            }
            else if (key.Length > 32)
            {
                key = key.Substring(0, 32);
            }
            return key;
        }

        ///   
        /// AES加密算法  
        ///   
        /// 明文字符串  
        /// 密钥(32位)  
        /// 字符串  
        public static string EncryptByAES(string input, string key)
        {
            byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 32));
            using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
            {
                aesAlg.Key = keyBytes;
                aesAlg.IV = Encoding.UTF8.GetBytes(IV.Substring(0, 16));

                ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);
                using (MemoryStream msEncrypt = new MemoryStream())
                {
                    using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                    {
                        using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
                        {
                            swEncrypt.Write(input);
                        }
                        byte[] bytes = msEncrypt.ToArray();
                        return ByteArrayToHexString(bytes);
                    }
                }
            }
        }

        ///   
        /// AES解密  
        ///   
        /// 密文字节数组  
        /// 密钥(32位)  
        /// 返回解密后的字符串  
        public static string DecryptByAES(string input, string key)
        {
            byte[] inputBytes = HexStringToByteArray(input);
            byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 32));
            using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
            {
                aesAlg.Key = keyBytes;
                aesAlg.IV = Encoding.UTF8.GetBytes(IV.Substring(0, 16));

                ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);
                using (MemoryStream msEncrypt = new MemoryStream(inputBytes))
                {
                    using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, decryptor, CryptoStreamMode.Read))
                    {
                        using (StreamReader srEncrypt = new StreamReader(csEncrypt))
                        {
                            return srEncrypt.ReadToEnd();
                        }
                    }
                }
            }
        }

        /// 
        /// 将指定的16进制字符串转换为byte数组
        /// 
        /// 16进制字符串(如:“7F 2C 4A”或“7F2C4A”都可以)
        /// 16进制字符串对应的byte数组
        public static byte[] HexStringToByteArray(string s)
        {
            s = s.Replace(" ", "");
            byte[] buffer = new byte[s.Length / 2];
            for (int i = 0; i < s.Length; i += 2)
                buffer[i / 2] = (byte)Convert.ToByte(s.Substring(i, 2), 16);
            return buffer;
        }

        /// 
        /// 将一个byte数组转换成一个格式化的16进制字符串
        /// 
        /// byte数组
        /// 格式化的16进制字符串
        public static string ByteArrayToHexString(byte[] data)
        {
            StringBuilder sb = new StringBuilder(data.Length * 3);
            foreach (byte b in data)
            {
                //16进制数字
                sb.Append(Convert.ToString(b, 16).PadLeft(2, '0'));
                //16进制数字之间以空格隔开
                //sb.Append(Convert.ToString(b, 16).PadLeft(2, '0').PadRight(3, ' '));
            }
            return sb.ToString().ToUpper();
        }
    }
}

js加密包地址 https://pan.baidu.com/s/1ha2i-e9WiRCIkMjrHZcLuw     https://www.oschina.net/p/crypto-js

参考网站:https://www.cnblogs.com/wz122889488/p/6899615.html

转载于:https://www.cnblogs.com/5tomorrow/p/9281036.html

你可能感兴趣的:(CryptoJS 、C#互通加解密(AES版))