0
点赞
收藏
分享

微信扫一扫

前端实现AES加密

张宏涛心理 2022-02-16 阅读 74

1、安装crypto-js

npm install --save crypto-js  

2、引入crypto-js

import CryptoJS from 'crypto-js'

3、在util文件夹中新建AES.js文件,添加代码

import CryptoJS from 'crypto-js'
export default {
    // 加密
    encrypt(key , iv , data){
        if( typeof data === "object" ){
            // 如果传入的data是json对象,先转义为json字符串
            try {
                data = JSON.stringify(data)
            } catch (error) {
                console.log("error:",error)
            }
        }
         // 统一将传入的字符串转成UTF8编码
        const dataHex = CryptoJS.enc.Utf8.parse( data ) // 需要加密的数据
        const keyHex = CryptoJS.enc.Utf8.parse( key ) // 秘钥
        const ivHex = CryptoJS.enc.Utf8.parse( iv ) // 偏移量
        const encrypted = CryptoJS.AES.encrypt( dataHex , keyHex , {
          iv: ivHex,
          mode: CryptoJS.mode.CBC, // 加密模式
          padding: CryptoJS.pad.Pkcs7
        })
        let encryptedVal = encrypted.ciphertext.toString()
        return encryptedVal //  返回加密后的值
	},
    
    // 解密
    decrypt( key , iv , encryptedVal ) {
    /*
      传入的key和iv需要和加密时候传入的key一致  
    */
     // 统一将传入的字符串转成UTF8编码
        let encryptedHexStr = CryptoJS.enc.Hex.parse( encryptedVal  );
        let srcs = CryptoJS.enc.Base64.stringify( encryptedHexStr );
        const keyHex = CryptoJS.enc.Utf8.parse( key ) // 秘钥
        const ivHex = CryptoJS.enc.Utf8.parse( iv ) // 偏移量
        let decrypt = CryptoJS.AES.decrypt( srcs , keyHex , {
            iv: ivHex, 
            mode: CryptoJS.mode.CBC, 
            padding: CryptoJS.pad.Pkcs7
        });
        let decryptedStr = decrypt.toString( CryptoJS.enc.Utf8 );
        return decryptedStr.toString();
    }
}
举报

相关推荐

0 条评论