php 5.5 des解密,PHP DES加密解密

这是一段 DES 解密的 PHP 代码。

参考自 http://php.net/manual/zh/function.mcrypt-module-open.php 中的例程。 本来也 没有什么难的。

但是我 解密 完 后 反复试,都是下面 这样的不可见 的乱码。

? ?]Y)?aw#?Y?????]m?/m?2??]C??f??V(?I?????~????? ?e=i"C??????

搞了大半天才 发现,是因为 对方 加密完之后 ,把二进制的 密文 转换成 十六进制的 给我传了过来 ,如13BD5122F55E706D13FB7D0F349A787D19E9D2334E268A15

大家看清楚啊, 这个可不能当作 密文本身 ,我就只因为 直接解密 这个 16进制的字符串 所以才 无法解密的。 需要 先把这个 16进制的 字符串 传化 回 二进制的 模样,再用 解密方法解密 ,就可以看到明文了 。

十六进制 转 二进制 的方法 是hex2bin

cryptare 这个函数 是 加密解密用的 ,第一个参数是 明文或者密文, 第二个参数是key, 第三个参数 0 表示 解密,1就是 加密。

注: 加密的时候可能用不到  $text = $this->hex2bin($text); 这一句。

function hex2bin($hexData)

{

$binData = "";

for($i = 0; $i < strlen ( $hexData ); $i += 2) {

$binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) );

}

return $binData;

}

function cryptare($text, $key, $crypt)

{

$text = $this->hex2bin($text);

$encrypted_data="";

$td = mcrypt_module_open('des', '', 'ecb', '');

$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_DEV_RANDOM);

mcrypt_generic_init($td, $key, $iv);

if($crypt)

{

$encrypted_data = mcrypt_generic($td, $text);

print $encrypted_data ;

}

else

{

$encrypted_data = mdecrypt_generic($td, $text);

}

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $encrypted_data;

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值