openssl_pkey_get_public没有公开公钥,“没有开始行””错误

生成公钥然后用函数openssl_pkey_get_public读取它 - $ publicKeyResource = bool(false)和消息: 错误:0906D06C:PEM例程:PEM_read_bio:无起始行
$privateKey = openssl_pkey_new(array('private_key_bits' => 2048, 'private_key_type' => OPENSSL_KEYTYPE_RSA));

$keyDetails = openssl_pkey_get_details($privateKey);

$publicKeyResource = openssl_pkey_get_public($keyDetails['key']);
怎么了? 附:
privateKey = 

array(3) {
  ["bits"]=>int(2048)

  ["key"]=>
  string(451) "-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApo5lpSuSQmAOXfqAmexj
IzjdGnd1X1gCKj5ko2DHgcR4XBlj1hbFNs1pzXx+R/UvLXTeF7dNQ+9AgXjEeRa6
71VbNxrUgvb/PHjEANwce7xBsnbu+dcSazyNHzx4ahWyEF4f3HyaJkGrT/Dgzcut
DO+yFAH9u8Hx26cj/8kyrtIHxazemnD+IDHRa3zOjKDmTfoDRKtOMTPVgFAsYBXn
tKcLyamCSBgpwfQwKfUUcYhfY1xD9UMhVXabSSiNQOiTMuOIZUHueO8UCp/tdK6a
LprUDBQ/tVmiV7ZMeZYMjh6XnK7higJ3WZp8RmD4PPeKbtG6j2AuGpbF/ddzD62T
XwIDAQAB
-----END PUBLIC KEY-----
"

  ["type"]=>
  int(0)
}
    
已邀请:
使用phpseclib的Crypt_RSA可能会更容易。例如。 createKey(2048)); echo $ publickey; ?> 更多信息: http://phpseclib.sourceforge.net/     
与我在PHP + OpenSSL中给出的答案相同:错误返回,但结果正确: 这显然是由openssl_pkey_get_public()引起的,它需要一个包含公钥而不是公钥的证书本身–它似乎加载公钥但仍然导致此错误。看那里的细节。     
很可能PHP的openSSL拒绝PEM形式的密钥。请尝试使用RSA表单     
原因: 此错误通常是由.crt文件开头的一个损坏字符引起的。因此,您可能在SSL证书文件(.crt)或SSL密钥中有额外的空间,额外的字符,额外的行等。     
我怀疑这在某些版本的PHP或OpenSSL中必定是一个错误,因为你发布的代码对我来说很好(PHP 5.2.6和OpenSSL 0.9.8g)。     

要回复问题请先登录注册