2

次のコードで PKCS#5 パディングが追加されているかどうかを知りたいですか? そうでない場合、追加する方法は?

$message = "insert plaintext message here";

$iv  = pack('H*', 'insert hex iv here');
$key = pack('H*', 'insert hex key here');

$enc = mcrypt_encrypt(MCRYPT_DES, $key, $message, MCRYPT_MODE_CBC, $iv);

echo bin2hex($enc);

また、DES/CBC/PKCS5Padding で作成された文字列を復号化するための PHP コードも作成したいと考えています。上記のコードを変更して復号化できると思います。

私にとって重要なことは、PKCS#5 Padding および Unpadding スクリプトを取得することです。

4

2 に答える 2

3

いいえ、追加されません。残念ながら、PHP / mcrypt は、メッセージがブロック サイズの N 倍になるまでゼロ パディングを使用します。

PKCS#5 パディングを追加するには、次の式を使用します。

p = b - l % b

はメッセージl長、bはブロック サイズ、%は剰余演算です。次に、暗号化を実行する前にp、値を含むバイトを末尾に追加します。p

于 2013-11-02T12:15:59.707 に答える
2

いくつかのスクリプトを見つけて以下に変更しました。PKCS#5 パディングが完了したかどうかを確認してください。

<?php 
function printStringToHex($text)
{
    $size = strlen($text);
    for($i = 0; $i < $size; $i++)
    {
        echo dechex(ord($text[$i])) . " ";
    }
}

function encrypt($input) 
{ 
    echo "<PRE>*** Encrypt *** </PRE>";
    echo "<PRE>Raw input: " . $input . "</PRE>";
    $size = mcrypt_get_block_size('des', 'cbc'); 
    echo "<PRE>Block: " . $size . "</PRE>";
    $input = pkcs5_pad($input, $size); 
    echo "<PRE>PKCS#5 padding: ";
    echo printStringToHex($input);
    echo "</PRE>";

    $td = mcrypt_module_open('des', '', 'cbc', ''); 
    $iv = pack('H*','insert hex iv here');
    $key = pack('H*','insert hex key here');
    mcrypt_generic_init($td, $key, $iv); 
    $data = mcrypt_generic($td, $input); 
    echo "<PRE>Raw output: " . $data . "</PRE>";
    echo "<PRE>Hex output: ";
    echo printStringToHex($data);
    echo "</PRE>";
    mcrypt_generic_deinit($td); 
    mcrypt_module_close($td); 
    $data = base64_encode($data); 
    echo "<PRE>B64 output: " . $data . "</PRE>";
    echo "<PRE>B64 output len: ";
    echo strlen($data) . "</PRE>";
    return $data; 
} 

function pkcs5_pad ($text, $blocksize) 
{ 
    $pad = $blocksize - (strlen($text) % $blocksize); 
    return $text . str_repeat(chr($pad), $pad); 
} 

$enc = encrypt("insert plaintext message here");
于 2013-11-02T14:02:55.037 に答える