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;
?>