DESede длинный ключ на PHP, а не на Java

Я пытаюсь конвертировать Java DESede расшифровка до версии PHP. Однако с тем же вводом PHP не может обеспечить идентичный вывод.

Джава:

public class ThreeDES {

private KeySpec             keySpec;
private SecretKeyFactory    keyFactory;
private Cipher              cipher;
public ThreeDES( String encryptionScheme, String encryptionKey )
throws EncryptionException {
try {
byte[] keyAsBytes = encryptionKey.getBytes("UTF-8");
keySpec = new DESedeKeySpec(keyAsBytes);
keyFactory = SecretKeyFactory.getInstance(encryptionScheme);
cipher = Cipher.getInstance(encryptionScheme);
} catch (InvalidKeyException e)
{
throw new EncryptionException( e );
}
catch (UnsupportedEncodingException e)
{
throw new EncryptionException( e );
}
catch (NoSuchAlgorithmException e)
{
throw new EncryptionException( e );
}
catch (NoSuchPaddingException e)
{
throw new EncryptionException( e );
}
}

public String decrypt( String encryptedString ) throws EncryptionException {
try {
SecretKey key = keyFactory.generateSecret( keySpec );
cipher.init( Cipher.DECRYPT_MODE, key );
BASE64Decoder base64decoder = new BASE64Decoder();
byte[] cleartext = base64decoder.decodeBuffer(encryptedString);
byte[] ciphertext = cipher.doFinal(cleartext);
return bytes2String( ciphertext );
}
catch (Exception e)
{
throw new EncryptionException( e );
}
}

private static String bytes2String( byte[] bytes )
{
StringBuffer stringBuffer = new StringBuffer();
for (int i = 0; i < bytes.length; i++)
{
stringBuffer.append( (char) bytes[i] );
}
return stringBuffer.toString();
}
}

PHP:

function decrypt($key, $data) {
$mcrypt_module = mcrypt_module_open(MCRYPT_TRIPLEDES, '', MCRYPT_MODE_ECB, '');
$mcrypt_iv     = mcrypt_create_iv(mcrypt_enc_get_iv_size($mcrypt_module), MCRYPT_RAND);
$decrypted     = mcrypt_decrypt(MCRYPT_TRIPLEDES, $key, base64_encode($data), MCRYPT_MODE_ECB, $mcrypt_iv);
mcrypt_module_close($mcrypt_module);
return pkcs5_unpad($decrypted);
}

function pkcs5_unpad($text) {
$pad = ord($text{strlen($text)-1});
if ($pad > strlen($text)) return false;
if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;
return substr($text, 0, -1 * $pad);
}

Учитывая следующие входные параметры, PHP не может обеспечить идентичный вывод:

$key = 'ASDFasdf12348983jklasdfJ2Jaf8';
$encrypted_data = 'cPap7+JIPS4=';

который должен расшифровать до:

COREF = 3

Тестовые коды для Java следующие:

try {
String encryptedStr = encrypted_data; // same value as PHP's $encrypted_data
String decryptedString = "";
ThreeDES desedeEncrypter = new ThreeDES("DSEede", key); // same value as PHP's $key
decryptedString = desedeEncrypter.decrypt(encryptedStr);
System.out.println(decryptedString);
} catch (ThreeDES.EncryptionException e) {
e.printStackTrace();
}

какие выводы: coRef=3, Однако следующий код PHP вызывает предупреждение о длине ключа.

echo decrypt($key, $encrypted_data);

Ключ размером 29 не поддерживается этим алгоритмом. Только ключи размером 24 поддерживаются в …

Как изменить код, чтобы использовать ключ длиной более 24 символов?

0

Решение

ну это странно,

Triple Des принимает только 24 байта в качестве ключа

Каждый ключ DES номинально хранится или передается в виде 8 байтов, каждый из
нечетная четность, [12], поэтому для набора ключей требуется 24 байта для варианта 1, 16 для
вариант 2 или 8 для варианта 3.

так что я думаю, что проблема в Вот

DESedeKeySpec объект:

/**
* Uses the first 24 bytes in <code>key</code> as the DES-EDE key.
* <p>
* The bytes that constitute the DES-EDE key are those between
* <code>key[0]</code> and <code>key[23]</code> inclusive
*
* @param key the buffer with the DES-EDE key material.
* @exception InvalidKeyException if the given key material is shorter
* than 24 bytes.
*/

так что я думаю, что DESedeKeySpec является своего рода обрезка вашего ключа длины 29 до 24, чтобы соответствовать его с tribledes требования .

РЕДАКТИРОВАТЬ еще одно важное замечание, которое mcrypt_ * продление устарело.

Эта функция УСТАРЕЛА с PHP 7.1.0. Опираясь на это
функция крайне не рекомендуется.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]