gpt4 book ai didi

php - openssl_encrypt,IV 为 0xFFFFFFFFFFFFFFFF,加密模式为 bf-cbc

转载 作者:行者123 更新时间:2023-12-03 18:29:49 25 4
gpt4 key购买 nike

我正在使用第三方软件,它以加密模式 CBC 和 IV 为 0xFFFFFFFFFFFFFFFF 在河豚中创建 key 。如何将这样的 IV 传递给 openssl_encrypt?源字符串的编码是 windows 1252。

我使用带有 UTF-8 的 PHP 7.3。

这是我目前的尝试:

$data = utf8_decode('12345678');

// if(strlen($data) % 8)
// $data = str_pad($data, strlen($data) + 8 - strlen($data) % 8, "\0");

$opts = OPENSSL_ZERO_PADDING;

if(defined('OPENSSL_DONT_ZERO_PAD_KEY'))
$opts = $opts | OPENSSL_DONT_ZERO_PAD_KEY;

echo openssl_encrypt($data, 'bf-cbc', utf8_decode('my-secret-key'), $opts, hex2bin('FFFFFFFFFFFFFFFF')) . '<br />';

$opts = OPENSSL_RAW_DATA | OPENSSL_ZERO_PADDING;

echo base64_encode(utf8_decode(openssl_encrypt($data, 'bf-cbc', utf8_decode('my-secret-key'), $opts, hex2bin('FFFFFFFFFFFFFFFF')))) . '<br />';

结果总是不同的。另一端是使用“Delphi Encryption Compendium Part I-III”。我无法更改其他软件创建加密数据的方式。 Delphi 软件使用的版本的源代码可以在这里找到: https://github.com/winkelsdorf/DelphiEncryptionCompendium/releases/tag/1

Delphi 函数如下所示:
function BlowfishEncryptStr(const InStr, Password: string;
var OutStr: string; Format: Integer = -1): Boolean;
var
Cipher: TCipher_Blowfish;

begin
Cipher := TCipher_Blowfish.Create(Password, nil);

try
try
Cipher.Mode := cmCBC;
OutStr := Cipher.CodeString(InStr, paEncode, Format);
Result := True;
except
Result := False;
end;
finally
FreeAndNil(Cipher);
end;
end;

使用以下参数调用该函数:
BlowfishEncryptStr('12345678', 'my-secret-key');

我尝试了 0xFFFFFFFFFFFFFFFF 的 IV,因为在这种情况下,这似乎是 Delphi Encryption Compendium 的默认设置。我也尝试过传递 0x0000000000000000 。

最佳答案

初始化向量只是二进制数据——不需要使用整数。所以答案很简单:$sIv= "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF"; .

剩下的就不清楚了:“结果总是不同的”是什么意思?确保 Delphi 程序总是产生相同的输出(否则它使用您尚未意识到的初始化或比您的脚本做的更多)。你的 PHP 脚本每次执行都应该产生相同的输出,即使第二个输出根本没有意义(对二进制数据进行 UTF 解码 - 你甚至忘记了“8”)。

关于php - openssl_encrypt,IV 为 0xFFFFFFFFFFFFFFFF,加密模式为 bf-cbc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56643954/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com