1、首先在小程序的根目錄下進行npm初始化
npm init
2、安裝cryptoJs
npm install crypto-js --save
3、在編輯器中勾選npm,並在工具欄裏構建npm
構建報錯找不到npm包
直接npm install crypto-js --save,然後構建包,是構建不成功的
需要按以上1-2-3步驟纔可以。
AES解碼爲空(不成功)的小問題
1、首先使用CryptoJS.AES.encrypt()這個方法加密,加密成功是一個對象,然後我們需要轉成字符串
2、在reture encrypteStr.toString()的時候,會被轉成Base64格式的字符
3、在return encrypteStr.ciphertext.toString()的時候,就不是base64格式了,而是128位的
4、在使用CryptoJs.AES.decrypt()解密的時候,需要的字符一定是Base64格式的,如果不是就需要轉成Base64
5、所以在解密的時候,先判斷傳過來的字符串是不是Base64格式的,如果不是我們再轉,是就不用轉了
6、一般我們前臺只做加密,後臺解密,密鑰呀,密鑰偏移量呀,字符格式,加密方式呀什麼的,都需要跟後臺約定好
7、加密好的字符再通過MD5來hash過後的值,這個值是不能解密的,但是兩個同樣的值,hash次數一樣,也是相等的
8、代碼
const CryptoJs = require('crypto-js');
const defaultKey = "V6VJTOYa3Ga1k6mwpm"; // 默認的key
const defaultIv = "DnPkv819zPXtW8wlkG"; // 默認的key 偏移量
/**
* 加密方法
* @param: str 需要加密的字符
* @param: key 密鑰
* @param: iv 密鑰偏移量
*/
function encrypt(str, key, iv) {
const keyStr = key ? encParse(key) : encParse(defaultKey);
const ivStr = iv ? encParse(iv) : encParse(defaultIv);
const encryptedStr = CryptoJs.AES.encrypt(str, keyStr, {
iv: ivStr,
mode: CryptoJs.mode.CFB,
padding: CryptoJs.pad.Pkcs7
});
// 直接toString()是base64格式的字符串
// ciphertext.toString() 是128位的字符串
return encryptedStr.toString();
}
/**
* 解密方法
* @param: str 需要解密的字符
* @param: key 密鑰
* @param: iv 密鑰偏移量
*/
function decrypt(str, key, iv) {
const keyStr = key ? encParse(key) : encParse(defaultKey);
const ivStr = iv ? encParse(iv) : encParse(defaultIv);
// 判斷str是否爲base64,如果不是就要轉base64,是了就不能再轉
const flag = isBase64(str);
if (!flag) {
// 轉爲base64之前要先轉16進制
str = CryptoJs.enc.Hex.parse(str);
// 只有base64格式的字符才能被解密
str = CryptoJs.enc.Base64.stringify(str);
}
const encryptedStr = CryptoJs.AES.decrypt(str, keyStr, {
iv: ivStr,
mode: CryptoJs.mode.CFB,
padding: CryptoJs.pad.Pkcs7
});
return encryptedStr.toString(CryptoJs.enc.Utf8);
}
/**
* 處理密鑰字符格式
* @param: key 需要轉格式的字符
*/
function encParse(key) {
// key = CryptoJs.enc.Utf8.parse(key);
return CryptoJs.enc.Latin1.parse(key);
}
/**
* 使用MD5 hash字符串
* @param: str 需要加密的字符串
* @param: times 需要hash的次數
*/
function md5(str, times = 1) {
for (let i = 0; i < times; i++) {
str = CryptoJs.MD5(str).toString();
}
return str;
}
/**
* 判斷是否是Base64格式的字符串
*/
function isBase64(str) {
let reg = /^(([A-Za-z0-9+/]{4})*([A-Za-z0-9+/]{3}=))|(([A-Za-z0-9+/]{4})*([A-Za-z0-9+/]{2}==))$/;
return reg.test(str);
}
export default {
decrypt,
encrypt,
md5
}