AES-256-CBC Encrpyt в Java/расшифровка в узле - ошибка: 1C80006B: подпрограммы поставщика:: неверная длина конечного блоJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 AES-256-CBC Encrpyt в Java/расшифровка в узле - ошибка: 1C80006B: подпрограммы поставщика:: неверная длина конечного бло

Сообщение Anonymous »

Я пытаюсь использовать шифрование AES-256-CBC для шифрования некоторых строк в Java, а затем расшифровать их в приложении Node.js с помощью криптобиблиотеки.
Вот Java шифрование:
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.SecretKeySpec;

import java.net.URLEncoder;
import java.security.spec.KeySpec;
import java.util.Base64;
import java.nio.charset.StandardCharsets;

public class TestEncrypt {
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 URLEncoder.encode(Base64.getEncoder().encodeToString(cipher.doFinal(strToEncrypt.getBytes(StandardCharsets.UTF_8))), StandardCharsets.UTF_8.toString());
}

public static byte[] decodeToBase64(String base64Value) {
return Base64.getDecoder().decode(base64Value);
}

public static String encryptData(String StringToEncode, String base256Key, String base256Iv, String salt) throws Exception {
String encryptedString = encrypt(StringToEncode, base256Key, decodeToBase64(base256Iv), salt);
return encryptedString;
}

public static void main(String args[]) throws Exception {
String originalValue = "hello world";
String encryptedValue = encryptData(originalValue, "TSP88GUiIrX5ZyBWAkvWk7JUMBaSlkVADhEB6gsGS9s=", "ZUCKXBlZT6/SdBxLoEJl0Q==", "ssshhhhhhhhhhh!!!!");
System.out.println("originalValue=" + originalValue);
System.out.println("encryptedValue=" + encryptedValue);
}
}

Вот расшифровка 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;
}

decrypt('V7qjZNuL%2FKBWRWc3hx1wRw%3D%3D', 'TSP88GUiIrX5ZyBWAkvWk7JUMBaSlkVADhEB6gsGS9s=', 'ssshhhhhhhhhhh!!!!', 'ZUCKXBlZT6/SdBxLoEJl0Q==');

Проблема в том, что когда я пытаюсь расшифровать то, что я зашифровал в приложении Java, я получаю эту ошибку
error:1C80006B:Provider routines::wrong final block length


Подробнее здесь: https://stackoverflow.com/questions/786 ... r-routines
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»