Как расшифровать сообщение с CryptoJS AES? У меня есть пример работающего узла - PullRequest
1 голос
/ 09 июля 2019

Я могу расшифровать зашифрованное AES-сообщение, используя криптографическую библиотеку Node следующим образом:

const crypto = require('crypto');
const encryptedData = 'b6ab428efbcb93c2f483178114ac0608530e54428f1378c6d3be108531b730d1888e562044cd3acb8844a04d9d7602d83b96f0a758248ffd07cd9c530b76c91c';

const decryptResponse2 = (data) => {
  const key = 'F5:A4:F4:AB:BF:68:CF:86:51:B4:AA';
  const iv = Buffer.from(data.substring(0, 32), 'hex');
  const payload = data.substring(32);
  const decipher = crypto.createDecipheriv('aes-256-cbc', key, iv).setAutoPadding(false);
  const decipherFinal = decipher.update(payload, 'hex', 'utf8') +   decipher.final('utf8');

  console.log(decipherFinal);
};

decryptResponse2(encryptedData);

Я создаю сценарий с использованием библиотеки crypto-js, так как он доступен для использования в браузере.Код, который я попробовал, выглядит следующим образом:

const crypto = require('crypto-js');
const encryptedData = 'b6ab428efbcb93c2f483178114ac0608530e54428f1378c6d3be108531b730d1888e562044cd3acb8844a04d9d7602d83b96f0a758248ffd07cd9c530b76c91c';

const decryptResponse = (data) => {
  const key = 'F5:A4:F4:AB:BF:68:CF:86:51:B4:AA';
  const iv = Buffer.from(data.substring(0, 32), 'hex');
  const payload = data.substring(32);
  let decryptedData = crypto.AES.decrypt(
    payload,
    key,
    {
      iv: iv,
      mode: crypto.mode.CBC,
      padding: crypto.pad.NoPadding
    });
  console.log(decryptedData.toString());
}

decryptResponse(encryptedData);

Тем не менее, он не только генерирует неверно дешифрованные данные, но дешифрованное сообщение даже непоследовательно.Я не знаю, что я делаю неправильно, так как я мало знаю о шифровании и дешифровании.

Любая помощь будет сокращена.

1 Ответ

2 голосов
/ 09 июля 2019

Благодаря @GrafiCode, указавшему мне на правильное место , я смог решить ее, используя свойство format объекта конфигурации.

Ниже приведен код:

const crypto = require('crypto-js');
const encryptedData = 'b6ab428efbcb93c2f483178114ac0608530e54428f1378c6d3be108531b730d1888e562044cd3acb8844a04d9d7602d83b96f0a758248ffd07cd9c530b76c91c';

const decryptResponse = (data) => {
  const key = crypto.enc.Utf8.parse('F5:A4:F4:AB:BF:68:CF:86:51:B4:AA');
  const iv = crypto.enc.Hex.parse(data.substring(0, 32));
  const payload = data.substring(32);
  let decryptedData = crypto.AES.decrypt(
    payload,
    key,
    {
      iv: iv,
      mode: crypto.mode.CBC,
      // padding: crypto.pad.NoPadding,
      format: crypto.format.Hex
    });
  console.log(crypto.enc.Utf8.stringify(decryptedData));
}

decryptResponse(encryptedData);

Я прокомментировал padding: crypto.pad.NoPadding, так как в конце расшифрованных данных в момент его включения были непечатаемые символы.

...