6

私はこのトリプルDES暗号化コードをPHPで持っています

    $encryption_key = "CE51E06875F7D964";
    $data='tokenNo=test&securityCode=111' ;
    echo $desEncryptedData = encryptText_3des($data, $encryption_key);//outputs 3des encrypted data

function encryptText_3des($plainText, $key) {
    $key = hash("md5", $key, TRUE); 
    for ($x=0;$x<8;$x++) {
        $key = $key.substr($key, $x, 1);
    }
    $padded = pkcs5_pad($plainText,
        mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_CBC));
    $encrypted = base64_encode(mcrypt_encrypt(MCRYPT_3DES, $key, $padded, MCRYPT_MODE_CBC));
    return $encrypted;
}
 function pkcs5_pad ($text, $blocksize)   
{
    $pad = $blocksize - (strlen($text) % $blocksize);
    return $text . str_repeat(chr($pad), $pad);
}

データを次のように暗号化できますxcFEvIdLXc2fjhG1i4iPOQu5L6ahxwZVucDOPqeMM2E=

キーを取得したので、このデータをプレーン テキスト形式に復号化できますか?

こんな感じでやってみた

            $encryption_key = "CE51E06875F7D964";
        $data='xcFEvIdLXc2fjhG1i4iPOQu5L6ahxwZVucDOPqeMM2E=' ; //encrypted data
        echo $desEncryptedData = encryptText_3des($data, $encryption_key);//outputs 3des encrypted data

    function encryptText_3des($plainText, $key) {
        $key = hash("md5", $key, TRUE); 
        for ($x=0;$x<8;$x++) {
            $key = $key.substr($key, $x, 1);
        }
        $padded = pkcs5_unpad($plainText,
            mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_CBC));
        $encrypted = base64_encode(mcrypt_encrypt(MCRYPT_3DES, $key, $padded, MCRYPT_MODE_CBC));
        return $encrypted;
    }

    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);
    }

しかし、私はそれを行うことができませんでした.私がやっていることは間違っていますか?これを復号化する方法を提案してください?暗号化キー自体は、トリプル DES でデータを復号化するために使用されますか?助けてください

4

4 に答える 4

9

PHP 7.1以降では、mcrypt関数は非推奨です。openssl_encryptを使用した代替方法を次に示します。

$ciphertext = openssl_encrypt('string to be encrypted', 'DES-EDE3', 'key', OPENSSL_RAW_DATA);
$ciphertext = base64_encode($ciphertext);

このオンラインのTriple DES 暗号化ツールを使用して、クロス チェックを行うことができます。

他の利用可能な暗号については、PHP メソッドopenssl_get_cipher_methods()を呼び出すことができます

于 2019-08-16T02:27:19.827 に答える
8

これが解決策です:

public function encrypt($data, $secret)
{
    //Generate a key from a hash
    $key = md5(utf8_encode($secret), true);

    //Take first 8 bytes of $key and append them to the end of $key.
    $key .= substr($key, 0, 8);

    //Pad for PKCS7
    $blockSize = mcrypt_get_block_size('tripledes', 'ecb');
    $len = strlen($data);
    $pad = $blockSize - ($len % $blockSize);
    $data .= str_repeat(chr($pad), $pad);

    //Encrypt data
    $encData = mcrypt_encrypt('tripledes', $key, $data, 'ecb');

    return base64_encode($encData);
}

public function decrypt($data, $secret)
{
    //Generate a key from a hash
    $key = md5(utf8_encode($secret), true);

    //Take first 8 bytes of $key and append them to the end of $key.
    $key .= substr($key, 0, 8);

    $data = base64_decode($data);

    $data = mcrypt_decrypt('tripledes', $key, $data, 'ecb');

    $block = mcrypt_get_block_size('tripledes', 'ecb');
    $len = strlen($data);
    $pad = ord($data[$len-1]);

    return substr($data, 0, strlen($data) - $pad);
}

よろしく。

于 2015-01-28T15:19:39.363 に答える
6

https://github.com/iam-raihan96/3DES-ECB-Cryptography-in-PHP

ここで私はPHPで3DES-ECB暗号化を書きました。そこで、 「mcrypt」を使用した「Crypt_mcrypt 」と「openssl」を使用した「 Crypt_openssl 」の 2 つのクラス ファイルを取得します。あなたはそれらのどれでも使うことができますが、それは

「Crypt_openssl」を使用することを強くお勧めします

コードに mcrypt という単語を入力している場合は、おそらく間違いを犯しています。mcrypt の上に構築された比較的安全な暗号化ライブラリを提供することは可能ですが (以前のバージョンのdefuse/php-encryptionでは提供されていました)、コードを openssl に切り替えると、セキュリティ、パフォーマンス、保守性、および移植性が向上します。さらに良いことに、代わりに libsodium を使用してください。

于 2017-07-09T23:50:32.853 に答える