AES加密解密的使用方法

网上关于 AES 对称加密的算法使用很多,这里我在推荐一篇理解AES加密解密的使用方法,加深大家对 AES 算法的理解~

加密的情况下得先引入crypto-js库

可以在这个GitHub的https://github.com/brix/crypto-js上下载该js,它可以单独引入所需要加密方式的js;也可以引入一个crypto-js.js 这个文件,它相当于引入了所有的加密方式,我使用的就是后者一次引入所有的加密文件,这个文件也不是很大,还可以接受。

安装

https://www.npmjs.com/package/crypto-js

npm install crypto-js
var CryptoJS = require("crypto-js"); // 这里直接引用所有加密文件

下面我们就来说下关于AES的加密方式吧

示例:
* AES加密模式: CBC
* 填充: pkcs7 padding
* 数据块 128
* 加密因子:abcd
* 偏移量:1234567890123456
* 输出字符 hex
* 使用的字符集 uft8


```js
//  加密方法
//  data:要加密的字符串
//  key:加密因子
//  iv:偏移量
getAesString(data,key,iv){  
    const CryptoJS = require('crypto-js')
    var key  = CryptoJS.enc.Utf8.parse(key); // 加密因子
    var iv   = CryptoJS.enc.Utf8.parse(iv); // 偏移量
    var str = CryptoJS.enc.Utf8.parse(data); // 使用的字符集 uft8
    var encrypted = CryptoJS.AES.encrypt(str, key,
    {
        iv:iv,
        mode:CryptoJS.mode.CBC, // AES加密模式
        padding:CryptoJS.pad.Pkcs7 // 填充:  pkcs7 padding
    }).ciphertext.toString(); // 输出字符 hex
    return encrypted;
},

//  解密方法
//  data:要解密的字符串
//  key:加密因子
//  iv:偏移量
getDAesString(data,key,iv){// 解密
    const CryptoJS = require('crypto-js')
    var key  = CryptoJS.enc.Utf8.parse(key); // 加密因子
    var iv   = CryptoJS.enc.Utf8.parse(iv); // 偏移量
    const encryptedHexStr = CryptoJS.enc.Hex.parse(data);
    
    const str = CryptoJS.enc.Base64.stringify(encryptedHexStr)
    
    const decrypted = CryptoJS.AES.decrypt(str, key, 
    {
        iv:iv,
        mode:CryptoJS.mode.CBC, // AES加密模式
        padding:CryptoJS.pad.Pkcs7 // 填充:  pkcs7 paddin
    })
    return decrypted.toString(CryptoJS.enc.Utf8).toString()
}

输出:

console.log(this.getAesString('1234567','abcd','1234567890123456')) // af3e177c24d8fc9a94916a4732f99a1b
console.log(this.getDAesString('af3e177c24d8fc9a94916a4732f99a1b','abcd','1234567890123456')) // 1234567

AES后输出hex 分为 16进制和Base64

上面代码写的是16进制,那么下面我们来说下Base64 进制的

getAesString(data,key,iv){//  加密
    const CryptoJS = require('crypto-js')
    var key  = CryptoJS.enc.Utf8.parse(key);
    var iv   = CryptoJS.enc.Utf8.parse(iv);
    var encrypted =CryptoJS.AES.encrypt(data,key,
        {
            iv:iv,
            mode:CryptoJS.mode.CBC,
            padding:CryptoJS.pad.Pkcs7
        });
    return encrypted.toString();    // 返回的是base64格式的密文
},
getDAesString(encrypted,key,iv){//  解密
    const CryptoJS = require('crypto-js')
    var key  = CryptoJS.enc.Utf8.parse(key);
    var iv   = CryptoJS.enc.Utf8.parse(iv);
    var decrypted = CryptoJS.AES.decrypt(encrypted,key,
        {
            iv:iv,
            mode:CryptoJS.mode.CBC,
            padding:CryptoJS.pad.Pkcs7
        });
    return decrypted.toString(CryptoJS.enc.Utf8);     
}

输出

console.log(this.getAesString('1234567','abcd','1234567890123456')) // rz4XfCTY/JqUkWpHMvmaGw==
console.log(this.getDAesString('rz4XfCTY/JqUkWpHMvmaGw==','abcd','1234567890123456')) // 1234567

AES256加密

上面的例子写的都是128加密,下面我们来看看256加密方式
其实都差不多,但感觉用的库有些不一样,方法也不一样,至少我这里是这样的

就直接上示例吧:

// 加密
aes256CeateCipheriv(data:any, key_:string, iv_:string){
    const crypto = require('crypto');
    
    let cipher = crypto.createCipheriv('AES-256-CBC', key_, iv_);
    let encrypted = cipher.update(data, 'utf8', 'hex');
    encrypted += cipher.final('hex');
    return encrypted;
}

// 解密
aes256CreateDecipheriv(data:any, key_:string, iv_:string){
    const crypto = require('crypto');

    let decipher = crypto.createDecipheriv('AES-256-CBC', key_, iv_);
    let decrypted = decipher.update(data, 'hex', 'utf8');
    return (decrypted + decipher.final('utf8'));
}

调用

fn2(){
    const key = "1234567890ABCDEF1234567890ABCDEF"; // 加密因子 
    const iv = "1234567890ABCDEF"; // 偏移量
    const phrase = "12345678"; // 加秘字符串
    
    console.log(this.aes256CeateCipheriv(phrase,key,iv)) //  ede50181759f8a535112c8a5476f4dc0
    console.log(this.aes256CreateDecipheriv('ede50181759f8a535112c8a5476f4dc0',key,iv))   // 12345678
}

参照这个https://gist.github.com/siwalikm/8311cf0a287b98ef67c73c1b03b47154

这里需注意的一点是,数据块 128 那么key的值不能超过16位,数据块256 那么key的值不能超过32位 而iv也有最大长度限制,我这里测试是16位

你可能感兴趣的:(AES加密解密的使用方法)