V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
a784910468
V2EX  ›  PHP

求助 openssl_encrypt,des-ecb 加密方式

  •  
  •   a784910468 · 2019-01-20 18:26:01 +08:00 · 4334 次点击
    这是一个创建于 2139 天前的主题,其中的信息可能已经有所发展或是发生改变。
    目前要做一个设备加密传输的流程,设备用的是十六进制,查了下 des 的一些资料
    $key = '0E329232EA6D0D73';
    $data = '8787878787878787';
    $result='0000000000000000';(这是最标准的一个十六进制加密的例子)


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

    我感觉是编码的问题,但是我又具体查不到该怎么解决,求有经验的大神指点迷津
    2 条回复    2019-01-20 22:18:24 +08:00
    VgV
        1
    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
        2
    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)));
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5516 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 08:49 · PVG 16:49 · LAX 00:49 · JFK 03:49
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.