openssl_spki_new
openssl_spki_new
(PHP 5 >= 5.6.0, PHP 7)
openssl_spki_new - 生成一个新的签名公钥和挑战
描述
string openssl_spki_new ( resource &$privkey , string &$challenge [, int $algorithm = 0 ] )
使用指定的哈希算法生成签名的公钥和质询
参数
privkey
privkey
应该设置为先前由openssl_pkey_new()生成的私钥(或以其他方式从其他openssl_pkey函数系列获得)。密钥的相应公开部分将用于签署CSR。
challenge
与SPKAC相关的挑战
algorithm
摘要算法。请参阅openssl_get_md_method()。
返回值
返回一个签名的公钥和挑战字符串,或者在失败时返回NULL。
Errors/Exceptions
如果未知签名算法通过algorithm
参数传递,则发出E_WARNING
级别错误。
示例
Example #1 openssl
_
spki
_
new() example
用缺省摘要生成新的SPKAC(MD5)
<?php
$pkey = openssl_pkey_new('secret password'
$spkac = openssl_spki_new($pkey, 'testing'
if ($spkac !== NULL) {
echo $spkac;
} else {
echo "SPKAC generation failed";
}
?>
上面的例子会输出类似于:
MIICRzCCAS8wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDM3V3sS4o4
mB9dczziRnjGAmSp+JwPrHoYMAFGvDNmZGyiWfU586X4BKs++BAj7e/FsAfno0Hd
hN9FwpCNFSox30L03nQvLYJE7f/WqigwBeMRT7Op/xvFks4sT70xP2HRYv4KqP9a
WRcKU6cFH8VxhFhqM2txEIxZKdFLaL28yT7bEDmcglf4JLDdgNMb9rET1dkgtKE6
dOaJHPGjf1uvnOH4YwkQr7n4sLUR3Kdbh0ZJAFuQVDZulo+LLzxBBkqJJcB6FhF+
oXCdHTKZnqAhpWDz+NXYytAmevab6IYm5TWPWsJUv1YKJA5lg2mXbbloIZlN9Mgc
i9fi03bdw+crAgMBAAEWB3Rlc3RpbmcwDQYJKoZIhvcNAQEEBQADggEBALyUvP/o
pPSoWBlorFyZ2RnGwKf9qMpE0q2IJP7G3oDR4LyK/m933DUiZ+YnqThrH/CWb4Ek
y5I3OCyl3S4wCuU1ibZZwDVwYShr5ELp0J9PEf7qMQZOhNsizoC7k+Czb2xB6hYW
sKfsfTKm3cXBtH3fdgc/Z1Z7VSWnAzYo38snqm72NTf5yFRnrQdphNNXi+kn1zHA
lxXRyFDXHOcYsOnwAWfyXFA4QDHQ0ezz0UoCY8gJXovcZb4GRYqOLUAsF2HcNboy
29WN8VqE29sL9QxVZFlwMcqyoLcNnyw38GvNvAGqSvzzbnEFP2MAQXJVe0H0hdp/
MML5G2iNVgNozAo=
另请参阅
openssl
_
spki
_
new()
- openssl_spki_export_challenge() - 使用签名的公钥和挑战导出挑战
- openssl_spki_export() - 导出有效的PEM格式的公钥已签名的公钥和质询
- openssl_csr_new() - 生成一个CSR
- openssl_csr_sign() - 用另一个证书(或其本身)签署CSR并生成证书
← openssl_spki_export
openssl_spki_verify →