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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...