在PHP中,openssl_sign函数用于使用私钥对数据进行签名。其基本用法如下:
openssl_sign(string $data, string &$signature, mixed $private_key [, mixed $algorithm = OPENSSL_ALGO_SHA256]): bool
参数说明:
- $data: 要签名的数据。
- $signature: 签名后的数据将会存储在此变量中。
- $private_key: 用于签名的私钥,可以是私钥的文件路径、资源或者 PEM 格式的私钥字符串。
- $algorithm: 签名算法,默认为OPENSSL_ALGO_SHA256。
示例:
$data = "https://www.yisu.com/ask/Hello, world!"; $private_key = file_get_contents("private_key.pem"); if (openssl_sign($data, $signature, $private_key, OPENSSL_ALGO_SHA256)) { echo "Signature: " . base64_encode($signature); } else { echo "Failed to sign data"; }
注意:在使用openssl_sign函数之前,你需要先加载私钥,可以通过file_get_contents将私钥文件读取为字符串,或者使用openssl_pkey_get_private函数获取私钥资源。