要验证使用openssl_pkey_new()
生成的密钥,您可以执行以下操作:
-
首先,确保已安装并启用了PHP的OpenSSL扩展。您可以通过运行
phpinfo()
函数来检查这一点。 -
使用
openssl_pkey_new()
生成一个新的私钥和公钥对。例如:
$config = array( "digest_alg" => "sha512", "private_key_bits" => 4096, "private_key_type" => OPENSSL_KEYTYPE_RSA, ); $res = openssl_pkey_new($config);
- 从生成的资源中提取私钥和公钥:
openssl_pkey_export($res, $privateKey); $publicKey = openssl_pkey_get_details($res); $publicKey = $publicKey["key"];
- 使用私钥对数据进行签名,然后使用公钥验证签名:
$data = "https://www.yisu.com/ask/This is a test message"; // 使用私钥对数据进行签名 openssl_sign($data, $signature, $privateKey, OPENSSL_ALGO_SHA512); // 使用公钥验证签名 $isValid = openssl_verify($data, $signature, $publicKey, OPENSSL_ALGO_SHA512); if ($isValid == 1) { echo "The signature is valid."; } elseif ($isValid == 0) { echo "The signature is not valid."; } else { echo "An error occurred while verifying the signature."; }
如果签名有效,那么生成的密钥就是有效的。请注意,这只是验证密钥对的一种方法,而不是验证密钥本身的唯一方法。在实际应用中,您还需要确保密钥的安全存储和传输。