Расшифровать AES 256 CBC с помощью crypto-js

У меня есть следующий ключ и 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
  }

person obliviousfella    schedule 13.08.2020    source источник


Ответы (1)


Ваш ключ и 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>

person Robby Cornelissen    schedule 13.08.2020