преобразовать алгоритм mcrypt в openssl PHP (MCRYPT_TripleDES, MCRYPT_MODE_CB C) - PullRequest
0 голосов
/ 05 апреля 2020

У меня есть код расшифровки, который использует устаревший mcrypt, мне нужно преобразовать эту функцию, чтобы использовать openssl. Есть много похожих вопросов о Stackoverflow, но они мне не помогли.

Вот функция расшифровки:

    public function decrypt($str, $key){
    //input
    $str = '9ACF38C842B3522415364850EAD1909BD43FD590BE3CBD539AD5FF6C7465973ABD61E8371E03282605ED06C994DF394244B7E7DAD54A046510484FAA724330C4C95A527D7891151E7C195D4136CBD70A87D1BD1F75473CF6B45A3F2FA8231DD71FFB4150E0BF4B133ECAA5ACC82CFD74903E21BC6EECB4B33AF39B8AF0C183A64002CFC125A55685C69A13192F3A9A4FDAC860E90C3FB6D125285E9E687BEFBE05707E131FC7ABE25FE35AB114FAE8A247B8C0F3DBA8AA74396D10564B7A0617EED913ED';
    $key = '10,10,10,10,10,10,10,10';

    //expected output:
    //'6706598320;67005551;100;00;YKB_TST_090519001330;0;0;https://setmpos.ykb.com/PosnetWebService/YKBTransactionService;posnettest.ykb.com;2225;N;0;Not authenticated;1557398383820;TL'
    outputsrand((double) microtime() * 10000000);
    $block = @mcrypt_get_block_size(MCRYPT_TripleDES, MCRYPT_MODE_CBC);
    $td = @mcrypt_module_open(MCRYPT_TripleDES, '', MCRYPT_MODE_CBC, '');
    $ks = @mcrypt_enc_get_key_size($td);

    if (strlen($str) < 16 + 8) return false;

    // Get IV
    $iv = pack("H*", substr($str, 0, 16));

    // Get Encrypted Data
    $encrypted_data = pack("H*", substr($str, 16, strlen($str)-16-8));

    // Get CRC
    $crc = substr($str, -8);

    // Check CRC
    /*if (!$this->checkCrc(substr($str, 0, strlen($str)-8), $crc)) {
        return "CRC is not valid! ($crc)";
    }*/

    // Initialize
    @mcrypt_generic_init($td, substr(strtoupper(md5($key)), 0, $ks), $iv);

    // Decrypt Data
    $decrypted_data = @mdecrypt_generic($td, $encrypted_data);

    $packing = ord($decrypted_data[strlen($decrypted_data) - 1]);

    if ($packing and ($packing < $block)) {
        for($P = strlen($decrypted_data) - 1; $P >= strlen($decrypted_data) - $packing; $P--) {
            if (ord($decrypted_data[$P]) != $packing) {
                $packing = 0;
            }
        }
    }

    return substr($decrypted_data, 0, strlen($decrypted_data) - $packing);

Я пытался:

$encrypted_data = pack("H*", substr($str, 16, strlen($str)-16-8));
$iv = pack("H*", substr($str, 0, 16));
/returns FALSE when sample input above given
$decrypted_data = openssl_decrypt($encrypted_data, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA, $iv);

Может кто-нибудь помогите мне пожалуйста?

1 Ответ

0 голосов
/ 05 апреля 2020

Я пропустил шаг преобразования ключа, работая следующим образом:

$decrypted_data = openssl_decrypt($encrypted_data, 'des-ede3-cbc', substr(strtoupper(md5($key)), 0, 24), OPENSSL_RAW_DATA, $iv);
...