使用CBC模式和密钥和IV规范密钥使用3DES算法加密的PHP代码

时间:2014-04-17 21:40:31

标签: php encryption 3des tripledes cbc-mode

我尝试使用3des(CBC)使用php中的密钥和IV规范密钥加密以下数据,但我没有得到相同的输出,我得到这个在线工具(http://symmetric-ciphers.online-domain-tools.com/

//input
$data = "Id=120278;timestamp=2009-02-05 08:28:39.195";
$key = "80127ECD5E40BB25DB14354A3795880DF2B459BB08E1EE6D";
$iv = "331BA9C5A7446C98";

//output from online tool. I should get the same result in my php code
$result = "1C80CBCE1713128176499C7A3DFB8779156B31B8DEF2F667A7100F1C3AEFABACB24283CFDF 5D312D A0074897138684BC";

按照我试过的PHP代码

$string = "Id=120278;timestamp=2009-02-05 08:28:39.195";
$iv = "331BA9C5A7446C98";
$passphrase = "80127ECD5E40BB25DB14354A3795880DF2B459BB08E1EE6D"; 
$encryptedString = encryptString($string, $passphrase, $iv);

function encryptString($unencryptedText, $passphrase, $iv) { 
  $enc = mcrypt_encrypt(MCRYPT_3DES, $passphrase, $unencryptedText, MCRYPT_MODE_CBC, $iv); 
  return base64_encode($enc);
}

1 个答案:

答案 0 :(得分:1)

试试这个:

 function encrypt3DES($key,$iv,$text_enc){
       $block = mcrypt_get_block_size('tripledes', 'cbc');
       $pad = $block - (strlen($text_enc) % $block);
       $text_enc .= str_repeat(chr($pad), $pad);
       $text_enc = mcrypt_encrypt(MCRYPT_3DES, $key, $text_enc, MCRYPT_MODE_CBC, $iv);
       $text_enc = base64_encode ($text_enc);
       return $text_enc;
   }