您的位置:首页 > 编程语言 > PHP开发

php做DES加密,仿PKCS5填充方式做自定义字符填充

2010-08-17 18:43 471 查看
首先,我们来看手册(只有很旧的手册上有)上的这一段代码,剖析了PKCS5填充过程。

<?php
function encrypt_something($input)
{
$size = mcrypt_get_block_size('des', 'ecb');
$input = pkcs5_pad($input, $size);

$key = 'YOUR SECRET KEY HERE';
$td = mcrypt_module_open('des', '', 'ecb', '');
$iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
mcrypt_generic_init($td, $key, $iv);
$data = mcrypt_generic($td, $input);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
$data = base64_encode($data);
return $data;
}

//填充部分,如果block为8字节,注意当加密字节数刚好是8的整数倍,也要在结尾填充8个字节
function pkcs5_pad ($text, $blocksize)
{
$pad = $blocksize - (strlen($text) % $blocksize);
return $text . str_repeat(chr($pad), $pad);
}

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


PKCS5填充的是要填充的字节数,下面看我据此改造的可以填充任意字符的DES加密。

<?php
function makePattern( $key, $text )
{
$blocksize = mcrypt_get_block_size( 'des', 'ecb' );
$padn = $blocksize - ( strlen( $text ) % $blocksize );
$pad = substr( strrev( $text ), 0, 1 );      //注意此处为我自定义的填充字符
$text = $text.str_repeat( $pad, $padn );

$td = mcrypt_module_open( 'des', '', 'ecb', '' );
$iv = mcrypt_create_iv ( mcrypt_enc_get_iv_size( $td ), MCRYPT_RAND );
mcrypt_generic_init( $td, $key, $iv );
$data = mcrypt_generic( $td, $text );
mcrypt_generic_deinit( $td );
mcrypt_module_close( $td );
return base64_encode( $data );
}
?>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: