PHP 钠解密返回 False

问题描述

我是 PHP 和 stackoverflow 的新手,因此可能会发生一些错误。如果有,请通知我,我会尽快解决

我的加密功能

function encrypt($data){
$nonce = random_bytes(sodium_CRYPTO_SECRETBox_NONCEBYTES);
$ciphertext = sodium_crypto_secretBox($data,$nonce,$GLOBALS['key']);
$ciphertext = base64_encode($ciphertext);
$ciphertext .= "[-SPLIT-]" . base64_encode($nonce);

return $ciphertext;}

我的解密功能

function decrypt($data){   
$data = explode("[-SPLIT-]",$data);
$ciphertext = base64_decode($data[0]);
$nonce = base64_decode($data[1]);
$plaintext = sodium_crypto_secretBox_open($ciphertext,$GLOBALS['key']);

if(!$plaintext){$plaintext = "Failed";}
return $plaintext;}

我已经做了足够多的测试,知道我正在将从加密函数返回的 $ciphertext 传递给解密函数

如何使函数返回在我的加密函数中加密的解密字符串?

解决方法

发现我的问题,一个简单的 print_r() 把我搞砸了。上面的代码按预期工作,我将很快发布一些改进。

相关问答

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