• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Blowfish加密,分别使用PHP和C++实现,但结果不同.该如何处理

php 搞代码 3年前 (2022-01-24) 19次浏览 已收录 0个评论

Blowfish加密,分别使用PHP和C++实现,但结果不同…
先是MD5实验,结果相同,但使用Blowfish实验,怎么做也成功不了
调用如下:

<?php<br />     <br />    $cipher = mcrypt_module_open(MCRYPT_B<p>+本文来源gao!%daima.com搞$代*!码9网(</p><strong>搞gaodaima代码</strong>LOWFISH, '', MCRYPT_MODE_ECB, '');<br /><br />    $iv   = '00000000';<br />    $key  = "strkey11";<br /><br />    $stext = '38A0E9312DDA8F7C16B9A12159168C76';<br />    $stext = md5($stext, true);<br />    //经过调试知道,在这时$stext的值与C++中MD5后的结果一致<br /><br />    if (mcrypt_generic_init($cipher, $key, $iv) != -1)<br />    {<br />        $dtext = mcrypt_generic($cipher,$stext );<br />        mcrypt_generic_deinit($cipher);<br /><br />        // Display the result in hex.<br />        printf("blowfish encrypted:<br>%s<br><br>",strtoupper(bin2hex($dtext)));<br />    }<br />    mcrypt_module_close($cipher);<br />

C++的是这样:

    MD5_CTX md5;<br />    unsigned char str[16];<br />    md5.MD5String(strSource.c_str() ,str);<br /><br />    BlockCipher *bf;<br />    char key[] = "strkey11";              //Key<br />    bf = new BlowFish();<br />    bf->setKey((void *)key, 8*8);<br /><br />    bf->encrypt((void *)str, 8);      //unsigned char str[16];<br />    bf->encrypt((void *)(str+8), 8);<br />    char temp1[4] = {0};<br />    char buff1[128] = {0};<br />    for(int i = 0;i<16;i++)<br />    {<br />        sprintf(temp1,"%02x",str[i]);<br />        strcat(buff1,temp1);<br />    }<br />    AnsiString strResult = String(buff1).UpperCase();<br />    delete bf;

——解决方案——————–
$iv = ‘00000000’; ???
按 bf->setKey((void *)key, 8*8); 理解
应该是
$iv = “\x00\x00\x00\x00\x00\x00\x00\x00”;
吧?

——解决方案——————–
IV is ignored in ECB. IV MUST exist in CFB, CBC, STREAM, nOFB and OFB modes.
MCRYPT_MODE_ECB的模式,$iv是忽略的,应该不是这个问题。

好像是加密之前要padding,你试试看
$size = mcrypt_get_block_size(MCRYPT_BLOWFISH, MCRYPT_MODE_ECB);
$input = pkcs5_pad($input, $size);

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;


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Blowfish加密,分别使用PHP和C++实现,但结果不同.该如何处理
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址