CryptoJS、Java中aes加密解密

CryptoJS、Java中aes加密解密,第1张

CryptoJS、Java中aes加密解密 前台 加密
// 16进制密文
function aesHexCryptoAesEncryption(word) {
  if (typeof (word) === 'object') { // 对象格式的转成json字符串
    word = JSON.stringify(word);
  }
  const key = CryptoJS.enc.Utf8.parse('1234567890000000') // 十六位
  const iv = CryptoJS.enc.Utf8.parse('1234567890000000'); // 十六位
  const encrypted = CryptoJS.AES.encrypt(word, key, {
    iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7,
  })
  return encrypted.ciphertext.toString();
}

明文:{"type":1}

密文:17e68f980a284534444d3ebeb210e936209330e3839ff2ca3cc1b569df566714

解密
// aes解密
function decrypt(word) {
    var key = CryptoJS.enc.Utf8.parse("1234567890000000"); 
    var iv = CryptoJS.enc.Utf8.parse("1234567890000000");
    var encryptedHexStr = CryptoJS.enc.Hex.parse(word);
    var srcs = CryptoJS.enc.base64.stringify(encryptedHexStr);
    var decrypt = CryptoJS.AES.decrypt(srcs, key, {
        iv: iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
    });
    var decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
    return decryptedStr.toString();
}
后台java

使用hutool工具

加密
AES aes = new AES(Mode.CBC, Padding.PKCS5Padding, "0CoJUm6Qyw8W8jud".getBytes(), "0102030405060708".getBytes());
String content = "test";
// 加密为16进制表示
String encryptHex = aes.encryptHex(content);
System.out.println(encryptHex); // 082852acd9c539e414295ed7417a1d22
解密
AES aes = new AES(Mode.CBC, Padding.PKCS5Padding, "0CoJUm6Qyw8W8jud".getBytes(), "0102030405060708".getBytes());
String decryptStr = aes.decryptStr("082852acd9c539e414295ed7417a1d22", CharsetUtil.CHARSET_UTF_8);
System.out.println(decryptStr);// test

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5682866.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-17
下一篇2022-12-17

发表评论

登录后才能评论

评论列表(0条)

    保存