OpenSSL 函数 业 ,精于勤 荒于嬉.

OpenSSL 函数 openssl_x509_parse 解析一个X509证书并作为一个数组返回信息

发表日期:2021-07-01 08:55:24 | 来源: | 分类:OpenSSL 函数

openssl_x509_parse

(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)

openssl_x509_parse解析一个X509证书并作为一个数组返回信息

说明

openssl_x509_parse(mixed $x509cert, bool $shortnames = true): array

openssl_x509_parse() 返回提供的 x509cert 证书的信息, 包括主题名称、发行方名称、目的、有效日期等字段。

参数

x509cert

shortnames

shortnames 控制数据在数组中的索引 - 如果 shortnamestrue (默认) 字段将以短名称的形式被索引, 否则将会使用长名称的形式 - 比如: CN 就是commonName的短名称格式。

返回值

返回的数据的结构是(故意的)还没有文档化,因为它仍然会发生变化。

阅读全文 »

OpenSSL 函数 openssl_x509_read 解析一个x.509证书并返回一个资源标识符

发表日期:2021-07-01 08:55:24 | 来源: | 分类:OpenSSL 函数

openssl_x509_read

(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)

openssl_x509_read解析一个x.509证书并返回一个资源标识符

说明

openssl_x509_read(mixed $x509certdata): resource

openssl_x509_read() 解析x509certdata提供的证书,并返回一个资源标识符。

参数

x509certdata

X509 证书。参见 Key/Certificate parameters 获取可用的值。

返回值

成功,返回一个资源标识符, 或者在失败时返回 false.

阅读全文 »

OpenSSL 函数 openssl_x509_verify Verifies digital signature of x509 certificate against a public key

发表日期:2021-07-01 08:55:24 | 来源: | 分类:OpenSSL 函数

      示例1
<?php 
$hostname = "news.php.net";
$ssloptions = array(    "capture_peer_cert" => true,     "capture_peer_cert_chain" => true,     "allow_self_signed"=> false,     "CN_match" => $hostname,    "verify_peer" => true,    "SNI_enabled" => true,    "SNI_server_name" => $hostname,);
 $ctx = stream_context_create( array("ssl" => $ssloptions) );
$result = stream_socket_client("ssl://$hostname:443", $errno, $errstr, 30, STREAM_CLIENT_CONNECT, $ctx);
$cont = stream_context_get_params($result);
$x509 = $cont["options"]["ssl"]["peer_certificate"];
$certparsed = openssl_x509_parse($x509);
foreach($cont["options"]["ssl"]["peer_certificate_chain"] as $chaincert){
    $chainparsed = openssl_x509_parse($chaincert);
    $chain_public_key = openssl_get_publickey($chaincert);
    $r = openssl_x509_verify($x509, $chain_public_key);
       if ($r==1)    {
        echo $certparsed['subject']['CN'];
        echo " was digitally signed by ";
        echo $chainparsed['subject']['CN']."\n";
    }
}
?>

阅读全文 »

全部博文(1580)
集速网 copyRight © 2015-2022 宁ICP备15000399号-1 宁公网安备 64010402001209号
与其临渊羡鱼,不如退而结网
欢迎转载、分享、引用、推荐、收藏。