Нужна эквивалентная Java для 3DES расшифровки PHP-кода
Это PHP-код, который у меня есть.
function decrypt($s_input, $s_key, $s_iv) {
$s_decrypted = pack("H*" , $s_input); // Hex to binary
$s_decrypted = mcrypt_decrypt (MCRYPT_3DES, $s_key, $s_decrypted, MCRYPT_MODE_CBC, $s_iv); // 3des decryption
return $s_decrypted;
}
echo encrypt('c37551bb77f741d0bcdc16497b4f97b1','123456781234567812345678','12345678' );
Что он в основном делает, так это расшифровывает зашифрованную строку 3des (сначала он преобразует шестнадцатеричную строку в двоичную с помощью функции pack, а затем выполняет фактическую расшифровку).
Это отлично работает в PHP-4 и выводит сообщение "Привет, мир".
Однако, если я запускаю эквивалентный код java (jdk 1.6), он выводит вывод мусора как - ªmjv=7xl_óä^"*?.
Может ли кто-нибудь помочь в устранении этой проблемы? Почему Java не работает должным образом расшифровка шестнадцатеричной строки.
private static String decrypt(String inputStr, String keyStr, String ivStr) throws Exception {
IvParameterSpec iv = new IvParameterSpec(ivStr.getBytes());
SecretKeySpec key = new SecretKeySpec(keyStr.getBytes(), "DESede");
inputStr = hexToString(inputStr, 2);
Cipher cipher = Cipher.getInstance("DESede/CBC/NoPadding");
cipher.init(Cipher.DECRYPT_MODE, key, iv);
byte[] decrypted = cipher.doFinal(inputStr.getBytes());
return new String(decrypted);
}
private static String hexToString(String input, int groupLength) {
StringBuilder sb = new StringBuilder(input.length() / groupLength);
for (int i = 0; i < input.length() - groupLength + 1; i += groupLength) {
String hex = input.substring(i, i + groupLength);
sb.append((char) Integer.parseInt(hex, 16));
}
return sb.toString();
}
public static void main(String[] args) throws Exception {
String decryptSignature = decrypt("c37551bb77f741d0bcdc16497b4f97b1", "123456781234567812345678", "12345678");
System.out.println(decryptSignature);
}
1 answers
Есть несколько вещей, которые вам следует проверить. Возможно, вам поможет шифрование с использованием AES-128 в Java. Могут возникнуть проблемы с различиями в том, как вы обрабатываете ключи в коде PHP и Java. Вызов getBytes()
на String
в Java без кодировки почти всегда является плохой идеей. Плюс используемая обивка может быть проблемой. Из того, что я видел, PHP-колодки с символами null
по умолчанию, что не соответствует NoPadding
в Java. Наконец, метод hexToString
должен возвращать byte[]
вместо String
. Добавьте результат вызова Integer.parseInt(hex, 16)
в массив:
byte[] results = new byte[input.length() / groupLength];
...
//inside the loop
results[i / groupLength] = (byte) Integer.parseInt(hex, 16);
...
return results;