求助 openssl_encrypt,des-ecb 加密方式

2019-01-20 18:26:01 +08:00
 a784910468
目前要做一个设备加密传输的流程,设备用的是十六进制,查了下 des 的一些资料
$key = '0E329232EA6D0D73';
$data = '8787878787878787';
$result='0000000000000000';(这是最标准的一个十六进制加密的例子)


但是我在 php 里面,无论我用 openssl_encrypt 还是 mcrypt_encrypt,抑或是在那些“在线加密 /解密网站”上都不能得到上述的结果(即 encrypt($data,$key,'des-ecb')=='0000000000000000')

我感觉是编码的问题,但是我又具体查不到该怎么解决,求有经验的大神指点迷津
4173 次点击
所在节点    PHP
2 条回复
VgV
2019-01-20 21:48:36 +08:00
mcrypt_encrypt 加密失败

当参数密钥 key 长度大于 8 位时,函数返回 false,PHP 5.6 版本后,不再接受无效长度的 key and iv 参数
如果参数密钥 key 长度大于 8 位,mcrypt_decrypt() 函数会产生警告并且返回 FALSE,导致加密失败。

解决方案: 将密钥长度截取到 8 位,这样能兼容 5.6 后的 PHP 版本。
alvinbone88
2019-01-20 22:18:24 +08:00
echo bin2hex( base64_decode( openssl_encrypt( hex2bin('8787878787878787'), 'des-ecb', hex2bin('0E329232EA6D0D73'), $options=OPENSSL_ZERO_PADDING)));

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/528854

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX