久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP利用Socket獲取網(wǎng)站的SSL證書與公鑰

這篇文章主要給大家介紹了PHP利用Socket獲取網(wǎng)站的SSL證書與公鑰的相關(guān)資料,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看

通過(guò) php curl 請(qǐng)求網(wǎng)頁(yè)并不能獲取到證書信息,此時(shí)需要使用 ssl socket 獲取證書內(nèi)容。下面來(lái)一起看看看詳細(xì)的介紹:

示例代碼:

// 創(chuàng)建 stream context
$context = stream_context_create([
 'ssl' => [
  'capture_peer_cert' => true,
  'capture_peer_cert_chain' => true,
 ],
]);
 
$resource = stream_socket_client("ssl://$domain:$port", $errno, $errstr, 30, STREAM_CLIENT_CONNECT, $context);
$cert = stream_context_get_params($resource);
 
$ssl = $cert['options']['ssl'];
$resource = $ssl['peer_certificate'];
 
// 網(wǎng)站證書中只有公鑰,通過(guò) openssl_pkey_get_details 導(dǎo)出公鑰
 
$ret = [
 'crt' => '',
 'pub' => '',
];
 
$pkey = openssl_pkey_get_public($resource);
$ret['pub'] = openssl_pkey_get_details($pkey)['key'];
 
openssl_x509_export($resource, $pem);
$ret['crt'] = $pem;
 
foreach ($ssl['peer_certificate_chain'] as $resource)
{
 openssl_x509_export($resource, $pem);
 $ret['crt'] .= "\n" . $pem;
}
 
// 保存 $ret['crt'] 為 domain.crt
// 保存 $ret['pub'] 為 domain.pub
 
return $ret;

驗(yàn)證證書中的公鑰A是否正確,通過(guò)私鑰導(dǎo)出公鑰B,比較兩者發(fā)現(xiàn)一致。

$domain = 'blog.zhengxianjun.com';
$port = '443';
// ...
$pub_a = $ret['pub'];
 
$private_key_path = '/conf/ssl/blog.zhengxianjun.com.key';
 
// 證書沒(méi)有設(shè)置密碼,$passphrase 為空字符串
$pkey = openssl_pkey_get_private(file_get_content($private_key_path), $passphrase = '');
$pub_b = openssl_pkey_get_details($pkey)['key'];
 
// 兩者一致
var_dump($pub_a === $pub_b);

函數(shù) stream_socket_client 還有一個(gè)用途是當(dāng)知道服務(wù)器 IP 時(shí),能獲取到服務(wù)器可能可以使用的域名。

$resource = stream_socket_client("ssl://$ip:$port", $errno, $errstr, 30, STREAM_CLIENT_CONNECT, $context);
$cert = stream_context_get_params($resource);
 
// 解析 X.509 格式證書
$info = openssl_x509_parse($cert['options']['ssl']['peer_certificate']);
 
// 獲取證書中的可信域名列表
$domain = str_replace('DNS:', '', $info['extensions']['subjectAltName']);

以上可以看到獲取網(wǎng)站證書并不能獲得私鑰。

在一些使用 CDN 的站點(diǎn),如果使用了 HTTPS 同時(shí)又希望使用自有域名,是否需要將自己的私鑰提供給 CDN 廠商呢?實(shí)際上證書路徑與使用者名稱(支持 https 的域名)并不需要一致。

也就是使用自有域名并進(jìn)行 CDN 加速時(shí)不需要使用自有的 ssl 證書,只需將自己的 CDN 域名加到廠商證書的域名列表即可。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)的支持。

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開(kāi)發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 少妇一级淫片免费放 | 成人黄色免费 | 手机看片国产 | 亚洲国产网站 | av在线天堂网 | 久操福利 | 精品日韩在线观看 | 黄www.| 欧美在线一级 | 欧美性猛交99久久久久99按摩 | 欧美专区在线观看 | 91精品国产99久久久久久红楼 | 少妇精品视频 | 色天堂视频 | 欧美日韩精品久久久免费观看 | 欧美成人一区二区三区片免费 | 中文字幕免费 | 日韩网站在线观看 | 成人h片在线观看 | 欧美视频在线观看一区 | 国产精品免费一区二区三区 | 成人免费精品 | 中文字幕精品在线观看 | 香蕉视频在线观看网站 | 国产黄av | 日本一级淫片色费放 | 久久精品一区二区国产 | 婷婷综合五月天 | 欧美激情视频一区二区 | 一区二区三区成人 | 国产精品黄色 | 91久久久久 | 亚洲成人av | 日日操天天操 | 一区二区日韩 | 狠狠干网站| 欧美精品亚洲精品 | 国产视频999 | 夜夜精品视频 | a天堂在线视频 | 日本一区二区不卡视频 |