3DES CBCモードで暗号化された暗号文があり、復号化に問題があります。私は次の情報を持っています(実際の値ではありません):
<?php
// Three 16 character long keys
$key1 = '1234567890123456';
$key2 = '6543210987654321';
$key3 = '6549873210456123';
// The initialisation vector
$ivec = '0102030405060708';
// A token which looks something like this
$token = '2ad82e09e3b4e7c491e4bb9fb7c606e1';
?>
復号化関数は、このブログ投稿にあるPHPクラスに基づいています。次のようになります。
<?php
function decrypt($key,$iv,$token) {
$td = mcrypt_module_open('tripledes', '', 'cbc', '');
$iv = substr($iv, 0, mcrypt_enc_get_iv_size($td));
$expected_key_size = mcrypt_enc_get_key_size($td);
$key = substr(md5($key), 0, $expected_key_size);
mcrypt_generic_init($td, $key, $iv);
$decrypted_string = trim(mdecrypt_generic($td, base64_decode($token)));
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return $decrypted_string;
}
?>
ただし、3つのキーをアルゴリズムにフィードする方法がわかりません。$key1。$key2。$key3のように、逆の順序でそれらをチェーンしてみましたが、役に立ちませんでした。
どんな助けでもいただければ幸いです。