JS中利用CryptoJS进行MD5SHA256BASE64AES加解密的方法与示例

45次阅读

共计 1470 个字符,预计需要花费 4 分钟才能阅读完成。

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 更强大一些。通过研究它的使用文档,可以发现更多惊喜。

正文完
 0