如何解决OpenSSL [des-ede3-cbc]加密php IV
我需要使用PHP加密数据以发送给公司。 他们说我必须使用我的钥匙和这个IV:
{(byte) 0x01,(byte) 0x02,(byte) 0x03,(byte) 0x04,(byte) 0x05,(byte) 0x06,(byte) 0x01,(byte) 0x02}
他们使用Java工作,并向我发送了以下代码段:
private static final IvParameterSpec iv = new IvParameterSpec (new byte []
{(byte) 0x01,(byte) 0x02});
如何将其转换为PHP?
我这样尝试:$iv = pack("nvc*",0x01,0x02,0x03,0x04,0x05,0x06,0x02);
,收到以下错误:警告:openssl_encrypt():IV传递的长度为10个字节,比所选密码预期的8个字节长,截断了,如果我改写了“ H *”作为参数,它告诉我有7个未使用的参数。
我该如何转换?
谢谢
解决方法
只需使用 hex2bin 函数将十六进制字符串转换为二进制数据即可。
下面您将找到算法“ DES-EDE3-CBC”的完整加密解密示例。
这是结果:
OpenSSL [des-ede3-cbc] encrypt php IV
decrypted: The quick brown fox jumps over the lazy dog
安全警告:该程序没有异常处理,仅用于教育目的。
代码:
<?php
echo 'OpenSSL [des-ede3-cbc] encrypt php IV' . PHP_EOL;
$plaintext = "The quick brown fox jumps over the lazy dog";
$algorithm = "DES-EDE3-CBC";
$key = "123456789012345678901234";
$ivHex = hex2bin("0102030405060102");
// encryption
$encrypted = openssl_encrypt($plaintext,$algorithm,$key,OPENSSL_RAW_DATA,$ivHex);
// decryption
$decrypted = openssl_decrypt($encrypted,$ivHex);
echo 'decrypted: ' . $decrypted . PHP_EOL;
?>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。