Libsodium“调用未定义的函数sodium_randombytes_buf”

时间:2017-09-14 09:53:51

标签: php libsodium

尝试按照示例here,但它给了我

Fatal error: Uncaught Error: Call to undefined function sodium_randombytes_buf()

最重要的是,密钥对似乎产生了奇怪的字符串,如:

kÿòjƒFDú{î—4]F◊î¸˜ßˆu…®_•A∞+

这是正常的吗?

这是我的代码

<?php

// send
$message = 'Hi, this is Alice';
$alice_to_bob_kp = sodium_crypto_box_keypair_from_secretkey_and_publickey(
    file_get_contents('./keys/sec-user-1_box_key.txt'),
    file_get_contents('./keys/pub-user-2_box_key.txt')
);
$nonce = sodium_randombytes_buf(SODIUM_CRYPTO_BOX_NONCEBYTES);
$ciphertext = sodium_crypto_box(
    $message,
    $nonce,
    $alice_to_bob_kp
);




// receive
$bob_to_alice_kp = sodium_crypto_box_keypair_from_secretkey_and_publickey(
    // $bob_box_secretkey,
    // $alice_box_publickey
    file_get_contents('./keys/sec-user-2_box_key.txt'),
    file_get_contents('./keys/pub-user-1_box_key.txt')
);
$nonce = sodium_randombytes_buf(SODIUM_CRYPTO_BOX_NONCEBYTES);
$plaintext = sodium_crypto_box_open(
    $ciphertext,
    $nonce,
    $bob_to_alice_kp
);
if ($plaintext === false) {
    die("Malformed message or invalid MAC");
}
die($plaintext);

1 个答案:

答案 0 :(得分:1)

示例中的代码没有sodium_randombytes_buf()这样的函数使用\Sodium\randombytes_buf()

编辑:

从错误历史中: &#34;钠_randombytes_ *符号已被删除了一段时间,因为PHP现在提供类似的功能而没有这个扩展&#34;

Bug #74896 sodium's .h defines some functions without .c implementation