CryptoJS (crypto.js) 為 JavaScript 提供了各種各樣的加密算法,由於它使用起來稍微有些復雜。所以本文主要着重說一下CryptoJS進行MD5/SHA256/BASE64/AES加解密的方法與示例。
准備工作
你可以下載CryptoJS(https://github.com/brix/crypto-js)到您本地,新建一個網頁然后通過console.log()進行調試,可以使用一款接口管理工具ApiPost(https://www.apipost.cn/)進行調試。
ApiPost是一款功能類似Postman的工具,但是融入了文檔分享功能,使用起來很方便。它內置了CryptoJS支持,所以我就以它作為調試工具了。
MD5加密
CryptoJS.MD5('待加密字符串').toString()
SHA256加密
CryptoJS.SHA256('待加密字符串').toString()
base64加密
CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse('待加密字符串'))
base64解密
CryptoJS.enc.Base64.parse("待解密字符串").toString(CryptoJS.enc.Utf8)
AES簡單加密
CryptoJS.AES.encrypt('待加密字符串', '秘鑰').toString()
AES簡單解密
CryptoJS.AES.decrypt('待解密字符串', '秘鑰').toString(CryptoJS.enc.Utf8)
自定義AES加解密函數
以上示例是2個簡單aes加解密方案,大部分情況下,我們需要自定義aes加解密更多的參數,比如加密模式、填充等。
const key = CryptoJS.enc.Utf8.parse("秘鑰"); //十六位十六進制數作為密鑰 const iv = CryptoJS.enc.Utf8.parse('偏移量'); //十六位十六進制數作為密鑰偏移量 //解密方法 function Decrypt(word) { let encryptedHexStr = CryptoJS.enc.Hex.parse(word); let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr); let decrypt = CryptoJS.AES.decrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }); let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8); return decryptedStr.toString(); } //加密方法 function Encrypt(word) { let srcs = CryptoJS.enc.Utf8.parse(word); let encrypted = CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }); return encrypted.ciphertext.toString().toUpperCase(); } //以上方法中 mode就是加密模式,padding是填充。
請求示例:
結尾
JS的加解密類庫很多,但是相對來說CryptoJS更強大一些。通過研究它的使用文檔,可以發現更多驚喜。