wsemi
Version:
A support package for web developer.
59 lines (51 loc) • 1.59 kB
JavaScript
import AES from 'crypto-js/aes'
// import encutf8 from 'crypto-js/enc-utf8'
// import padPkcs7 from 'crypto-js/pad-pkcs7'
import encutf8 from 'crypto-js/enc-utf8'
import encb64 from 'crypto-js/enc-base64'
import enchex from 'crypto-js/enc-hex'
import isestr from './isestr.mjs'
import isbol from './isbol.mjs'
/**
* 一般字串轉AES字串
* 使用AES-128-CBC加密,字串採用PKCS#7填充
*
* Unit Test: {@link https://github.com/yuda-lyu/wsemi/blob/master/test/aes2str.test.mjs Github}
* @memberOf wsemi
* @param {String} str 輸入一般字串
* @param {String} key 輸入加密key
* @param {Boolean} [base64=false] 輸入是否轉為base64字串,預設為false
* @returns {String} 回傳經AES轉換後字串,採Hex/base64顯示
* @example
*
* let str = '53616c7465645f5f47214797ac01bc03cceb69ebced4948501ab94ca9644a6dfd277456aead4432cb9c9d74c38c42c79'
* let key = '1234567890abcdefghijk'
* console.log(aes2str(str, key))
* // => 'test中文abcdefghijklmn'
*
*/
function aes2str(str, key, base64 = false) {
//check
if (!isestr(str)) {
return ''
}
if (!isestr(key)) {
return ''
}
if (!isbol(base64)) {
return ''
}
let c = ''
if (base64) {
let o = AES.decrypt(str, key)
c = o.toString(encutf8)
}
else {
let reb64 = enchex.parse(str)
let bytes = reb64.toString(encb64)
let decrypt = AES.decrypt(bytes, key)
c = decrypt.toString(encutf8)
}
return c
}
export default aes2str