///////////////////////////////////////前端代碼///////////////////////////////////////
@{
ViewBag.Title = "Login"; Layout = null; } <form method="post" onsubmit="CryptoLoginInfo()"> <label>用戶名:</label><input type="text" name="userId" id="userId" /> <label>密碼:</label><input type="text" name="passWord" id="passWord" /> <label><input type="submit" value="提交" /> </label> </form> <script src="~/Scripts/crypto-js-3.1.8/crypto-js-3.1.8/crypto-js.js"></script> <script src="~/Scripts/crypto-js-3.1.8/crypto-js-3.1.8/aes.js"></script> <script type="text/javascript"> function CryptoLoginInfo() { var key = "@ViewBag.AESKey"; document.getElementById("userId").value = Encrypt(document.getElementById("userId").value, key); document.getElementById("passWord").value = Encrypt(document.getElementById("passWord").value, key); } </script> <script type="text/javascript"> function Encrypt(source, key) { var key = CryptoJS.enc.Utf8.parse(key);//32位 var iv = CryptoJS.enc.Utf8.parse("1234567890000000");//16位 var srcs = CryptoJS.enc.Utf8.parse(source); var encrypted = CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }); return encrypted.ciphertext.toString(); } </script>
///////////////////////////////////////後臺代碼///////////////////////////////////////
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"; /// <summary> /// 獲取Aes32位密鑰 /// </summary> /// <returns></returns> 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; } /// <summary> /// AES加密算法 /// </summary> /// <param name="input">明文字符串</param> /// <param name="key">密鑰(32位)</param> /// <returns>字符串</returns> 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); } } } } /// <summary> /// AES解密 /// </summary> /// <param name="input">密文字節數組</param> /// <param name="key">密鑰(32位)</param> /// <returns>返回解密後的字符串</returns> 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(); } } } } } /// <summary> /// 將指定的16進制字符串轉換爲byte數組 /// </summary> /// <param name="s">16進制字符串(如:「7F 2C 4A」或「7F2C4A」均可以)</param> /// <returns>16進制字符串對應的byte數組</returns> 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; } /// <summary> /// 將一個byte數組轉換成一個格式化的16進制字符串 /// </summary> /// <param name="data">byte數組</param> /// <returns>格式化的16進制字符串</returns> 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-jsjavascript