Ссылка: я пытаюсь преобразовать расшифровку шифрования Java AES в NodeJs. Это то, что я пробовал до сих пор.
Я пытаюсь расшифровать aes-256-cbc, зашифрованный из Java, в приложении node.js. Код Java ссылается на приведенное выше:
Шифрование Java:
public static String encrypt(String strToEncrypt, String key, byte[] initialVector, String salt) throws Exception{
IvParameterSpec ivspec = new IvParameterSpec(initialVector);
SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256");
KeySpec spec = new PBEKeySpec(key.toCharArray(), salt.getBytes(), 65536, 256);
SecretKey tmp = factory.generateSecret(spec);
SecretKeySpec secretKey = new SecretKeySpec(tmp.getEncoded(), "AES");
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivspec);
return Base64.getEncoder().encodeToString(cipher.doFinal(strToEncrypt.getBytes("UTF-8")));
}
Передача следующих значений:
key = shh_password
initialVector = GKomBb2ZFCdL7XQiCtUJZQ==
salt = salt
Расшифровка Node.js:
const algorithm = 'aes-256-cbc';
const digest = 'sha256';
function decrypt(strToDecrypt, secretKey, salt, initialVector) {
const key = crypto.pbkdf2Sync(
secretKey,
Buffer.from(salt),
65536,
32,
digest
);
const iv = Buffer.from(initialVector, 'base64');
const decipher = crypto.createDecipheriv(algorithm, key, iv);
let decrypted = decipher.update(strToDecrypt, 'base64');
decrypted += decipher.final();
return decrypted;
}
Получаю эту ошибку при расшифровке с теми же деталями:
error:1C80006B:Provider routines::wrong final block length
Подробнее здесь: https://stackoverflow.com/questions/786 ... ng-final-b
Шифрование Java/дешифрование Node.js - ошибка: 1C80006B: подпрограммы поставщика:: неверная длина конечного блока ⇐ JAVA
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Шифрование AES на Python, расшифровка на PHP «неправильная длина блока»
Anonymous » » в форуме Python - 0 Ответы
- 21 Просмотры
-
Последнее сообщение Anonymous
-