Я не криптография profi и специально из-за того, что OpenSSL имеет много недостающей документации, я не уверен, как решить эту проблему.
У меня есть внешняя система, которая рассчитывает получить зашифрованные сообщения. В приведенном примере используется OpenSSL таким образом:
$ openssl enc -aes-256-cbc -a -in t.txt -k testpass
U2FsdGVkX1/RUdaSJKRXhHv3zUyTsQwu5/ar2ECKDlrNyH5GL4xRR4fgxkiWqkS1
cQstcoSIgWfRPSOFj/5OtdNLeNXiVR6MxSKJ+NvS9LyUD8+Rg6XIcYUvxR4gHi3w
DWT44LAMCpRAh1Q0t4Z2g7rwb0D05T6ygLaWvB5zD/xGZD3brTqSlWmiJb9Imgda
M6soZO7BhbYdqWqEUl5r6+EbkD21f6L3NX3hJFo+BJ+VFctiAlBO8NwT5l4ogo/s
GErm8gqRr57XoX/kvKAimg==
Если файл t.txt
содержит эту строку в одной строке:
AMOUNT=10&TID=#19:23&CURRENCY=EUR&LANGUAGE=DE&SUCCESS_URL=http://some.url/sucess&ERROR_URL=http://some.url/error&CONFIRMATION_URL=http://some.url/confirm&NAME=customer full name`
Я нашел этот другой вопрос, и я смог выполнить шифрование, используя следующий код:
String password = "passPhrase";
String salt = "15charRandomSalt";
int iterations = 100;
/* Derive the key, given password and salt. */
SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256");
KeySpec spec = new PBEKeySpec(password.toCharArray(), salt.getBytes(Charset.forName("UTF8")), iterations, 256);
SecretKey tmp = factory.generateSecret(spec);
SecretKey secret = new SecretKeySpec(tmp.getEncoded(), "AES");
/* Encrypt the message. */
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secret);
AlgorithmParameters params = cipher.getParameters();
byte[] iv = params.getParameterSpec(IvParameterSpec.class).getIV();
byte[] cipherText = cipher.doFinal(toBeEncrypted.getBytes("UTF-8"));
encryptedData = Base64.getEncoder().encodeToString(cipherText);
encryptedData += Base64.getEncoder().encodeToString(iv);
Что я не могу понять, так это то, как я должен сгенерировать аналогичный вывод (encryptedData) для того, что делает OpenSSL. У меня есть соль, iv и cipherText, это результат OpenSSL, полученный в кодировке Base64 в результате их конкатенации? или только один из них?
Единственное, что я разделяю с этой другой системой перед шифрованием, это фраза. Как они могут расшифровать результат, если им не известны соли и количество итераций?
Может кто-нибудь дать ответы на эти неизвестные параметры, а также сказать, является ли приведенный выше код эквивалентом процесса OpenSSL?