小程序使用npm包, 引入cryptoJs進(jìn)行AES加密跟MD5加密

1、首先在小程序的根目錄下進(jìn)行npm初始化

npm init

2、安裝cryptoJs

npm install crypto-js --save

3、在編輯器中勾選npm,并在工具欄里構(gòu)建npm


使用npm包.jpg

構(gòu)建報(bào)錯(cuò)找不到npm包

直接npm install crypto-js --save,然后構(gòu)建包,是構(gòu)建不成功的


構(gòu)建找不到包.jpg

需要按以上1-2-3步驟才可以。

AES解碼為空(不成功)的小問(wèn)題

1、首先使用CryptoJS.AES.encrypt()這個(gè)方法加密,加密成功是一個(gè)對(duì)象,然后我們需要轉(zhuǎn)成字符串
2、在reture encrypteStr.toString()的時(shí)候,會(huì)被轉(zhuǎn)成Base64格式的字符
3、在return encrypteStr.ciphertext.toString()的時(shí)候,就不是base64格式了,而是128位的
4、在使用CryptoJs.AES.decrypt()解密的時(shí)候,需要的字符一定是Base64格式的,如果不是就需要轉(zhuǎn)成Base64
5、所以在解密的時(shí)候,先判斷傳過(guò)來(lái)的字符串是不是Base64格式的,如果不是我們?cè)俎D(zhuǎn),是就不用轉(zhuǎn)了
6、一般我們前臺(tái)只做加密,后臺(tái)解密,密鑰呀,密鑰偏移量呀,字符格式,加密方式呀什么的,都需要跟后臺(tái)約定好
7、加密好的字符再通過(guò)MD5來(lái)hash過(guò)后的值,這個(gè)值是不能解密的,但是兩個(gè)同樣的值,hash次數(shù)一樣,也是相等的

8、代碼

const CryptoJs = require('crypto-js');
const defaultKey = "23d$%Q#kjwgsl@@$#@"; // 默認(rèn)的key
const defaultIv = "ogiGRWos02oH22301#"; // 默認(rèn)的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,如果不是就要轉(zhuǎn)base64,是了就不能再轉(zhuǎn)
  const flag = isBase64(str);
  if (!flag) {
    // 轉(zhuǎn)為base64之前要先轉(zhuǎn)16進(jìn)制
    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 需要轉(zhuǎn)格式的字符
 */
function encParse(key) {
  // key = CryptoJs.enc.Utf8.parse(key);
  return CryptoJs.enc.Latin1.parse(key);
}
/**
 * 使用MD5 hash字符串
 * @param: str 需要加密的字符串
 * @param: times 需要hash的次數(shù)
 */
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
}

項(xiàng)目地址:https://gitee.com/qinjunbang/crypto-demo

cryptoJs 插件地址:https://gitee.com/qinjunbang/crypto-demo

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容