为了账号安全,请及时绑定邮箱和手机立即绑定

通过 crypto-js 解密 AES 256 CBC

通过 crypto-js 解密 AES 256 CBC

RISEBY 2023-01-06 15:57:48
我有以下密钥和 IV 可以将07KxrSbGIoPCIYh0I16maw==解密为“496271”,我尝试搜索类似的问题,但我对加密知识的缺乏使我无法自己解决这个问题。get decryptedCode() {  var key = CryptoJS.enc.Utf8.parse(    "814591256d331af80bec0fa2bef1123e37e9f181f363af374787e24160275bce"  )  var iv = CryptoJS.enc.Utf8.parse("825b1f7c5f5edd614e8a0a0fef3c9ecf")  var ciphertext = CryptoJS.enc.Base64.parse("07KxrSbGIoPCIYh0I16maw==")  var encryptedCP = CryptoJS.lib.CipherParams.create({    ciphertext: ciphertext,    formatter: CryptoJS.format.OpenSSL   })  var decryptedWA = CryptoJS.AES.decrypt(encryptedCP, key, { iv: iv })  var decryptedUtf8 = decryptedWA.toString(CryptoJS.enc.Utf8)  console.log(decryptedUtf8) // this should be 496271 but I keep getting blank string  return decryptedUtf8  }
查看完整描述

1 回答

?
喵喔喔

TA贡献1735条经验 获得超5个赞

您的密钥和 IV 是十六进制编码的,因此要解析它们,您需要使用CryptoJS.enc.Hex.parse() 而不是CryptoJS.enc.Utf8.parse():


function getDecryptedCode() {

  var key = CryptoJS.enc.Hex.parse(

    "814591256d331af80bec0fa2bef1123e37e9f181f363af374787e24160275bce"

  );

  var iv = CryptoJS.enc.Hex.parse("825b1f7c5f5edd614e8a0a0fef3c9ecf");

  var ciphertext = CryptoJS.enc.Base64.parse("07KxrSbGIoPCIYh0I16maw==");

  var encryptedCP = CryptoJS.lib.CipherParams.create({

    ciphertext: ciphertext,

    formatter: CryptoJS.format.OpenSSL

  });

  var decryptedWA = CryptoJS.AES.decrypt(encryptedCP, key, {

    iv: iv

  });

  var decryptedUtf8 = decryptedWA.toString(CryptoJS.enc.Utf8);


  return decryptedUtf8;

}


console.log(getDecryptedCode()); // 496271

<script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/4.0.0/crypto-js.min.js"></script>



查看完整回答
反对 回复 2023-01-06
  • 1 回答
  • 0 关注
  • 551 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信