| <html> | |
| <head> | |
| <title>AES加解密</title> | |
| <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> | |
| <script src="/assets/js/aes.js"></script> | |
| <script> | |
| function getByteLen(val) { | |
| var len = 0; | |
| for (var i = 0; i < val.length; i++) { | |
| if (val[i].match(/[^\x00-\xff]/ig) != null) len += 3; | |
| else len += 1; | |
| } | |
| return len; | |
| } | |
| function onbtnEncrypto() { | |
| var plaintText = document.getElementById("input").value; | |
| var keyword = document.getElementById("inputkey").value; | |
| if (plaintText.replace(/(^\s*)|(\s*$)/g, "") == '') { | |
| alert("输入要加密的内容!"); | |
| return; | |
| } | |
| if (keyword.replace(/(^\s*)|(\s*$)/g, "") == '') { | |
| alert("输入要加密的key!"); | |
| return; | |
| } | |
| while (getByteLen(keyword) % 8 != 0) { | |
| keyword = keyword + "\0"; | |
| } | |
| var key = CryptoJS.enc.Utf8.parse(keyword); | |
| var encryptedData = CryptoJS.AES.encrypt(plaintText, key, { | |
| mode: CryptoJS.mode.ECB, | |
| padding: CryptoJS.pad.Pkcs7 | |
| }); | |
| encryptedData = encryptedData.ciphertext.toString(); | |
| document.getElementById("output").value = encryptedData; | |
| } | |
| function onbtnDecrypto() { | |
| var encryptedData = document.getElementById("input").value; | |
| var keyword = document.getElementById("inputkey").value; | |
| if (encryptedData.replace(/(^\s*)|(\s*$)/g, "") == '') { | |
| alert("输入要加密的内容!"); | |
| return; | |
| } | |
| if (keyword.replace(/(^\s*)|(\s*$)/g, "") == '') { | |
| alert("输入要加密的key!"); | |
| return; | |
| } | |
| while (getByteLen(keyword) % 8 != 0) { | |
| keyword = keyword + "\0"; | |
| } | |
| var key = CryptoJS.enc.Utf8.parse(keyword); | |
| var encryptedHexStr = CryptoJS.enc.Hex.parse(encryptedData); | |
| var encryptedBase64Str = CryptoJS.enc.Base64.stringify(encryptedHexStr); | |
| var decryptedData = CryptoJS.AES.decrypt(encryptedBase64Str, key, { | |
| mode: CryptoJS.mode.ECB, | |
| padding: CryptoJS.pad.Pkcs7 | |
| }); | |
| if (decryptedData.sigBytes < 0) { | |
| document.getElementById("output").value = "解密失败!密文或者key错误!"; | |
| return; | |
| } | |
| try { | |
| decryptedData.toString(CryptoJS.enc.Utf8) | |
| } catch(e) { | |
| document.getElementById("output").value = "解密失败!密文或者key错误!"; | |
| return; | |
| } | |
| var decryptedStr = decryptedData.toString(CryptoJS.enc.Utf8); | |
| document.getElementById("output").value = decryptedStr; | |
| } | |
| </script> | |
| </head> | |
| <body> | |
| <div> | |
| <br /> | |
| <textarea id="input" name="input" style="width: 80%" rows="8">这里是要加密的内容!</textarea> | |
| <br />key: | |
| <input id="inputkey" type="text" /> | |
| <br /> | |
| <p> <button id="en" class="btn" onclick="onbtnEncrypto()" style="width:100px">加密</button> <button id="de" class="btn" onclick="onbtnDecrypto()" style="width:100px">解密</button> </p> | |
| <textarea id="output" name="output" style="width: 80%" rows="10"></textarea> | |
| </div> | |
| </body> | |
| </html> |