php 5.6 mcrypt_encrypt,mcrypt_encrypt在PHP 5.6.9上无法正常工作

我有以下代码在

PHP 5.5.9上运行良好.

function index()

{

echo $this->encryptText_3des('TEST','JHHKJH9879');

}

function encryptText_3des($plainText, $key) {

$key = hash("md5", $key, TRUE);

for ($x=0;$x<8;$x++) {

$key = $key.substr($key, $x, 1);

}

$padded = $this->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);

}

加密发生得很好.但是在5.6.9中,在mcrypt_encrypt的PHP文档中,他们提到了

Invalid key and iv sizes are no longer accepted. mcrypt_encrypt() will now throw a warning and return FALSE if the inputs are invalid. Previously keys and IVs were padded with ‘\0’ bytes to the next valid size.

如何在不改变加密算法的情况下使用第五个参数修改当前代码?

我试过了

$iv_size = mcrypt_get_iv_size(MCRYPT_3DES, MCRYPT_MODE_CBC);

$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);

给$iv作为第五个参数.

但它没有成功.加密与早期加密不同.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值