3

Trying to follow the examples here, but it gives me

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

On top of that, the key pairs seems to be generating weird strings like:

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

Is that normal?

Here's my code

<?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);
2
  • You need to require in their files you need Commented Sep 14, 2017 at 9:56
  • it's an extension Commented Sep 14, 2017 at 9:58

1 Answer 1

1

There is no such function as sodium_randombytes_buf() the code in the example uses \Sodium\randombytes_buf().

Edit:

From the bug history: "The sodium_randombytes_* symbols have been removed a while back, as PHP now provide similar functions without this extension"

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

Sign up to request clarification or add additional context in comments.

9 Comments

They've used the prefix sodium_* instead of namespace in the newer version
You'll need to provide your code to reviev then.
ok. updated the question content
Take a look at my edited answer.
so instead can use random_bytes() php built in function? what about the weird kÿòjƒFDú{î—4]F◊î¸˜ßˆu…®_•A∞+ string generated from the key pairs?
|

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.