成功的 HTTPS 請(qǐng)求涉及 HTTP 用戶端驗(yàn)證 伺服器根據(jù)已知且受信任的根列表提供的 TLS 證書(shū) 證書(shū)。 PHP Curl 擴(kuò)充功能沒(méi)有什麼不同;捲曲 擴(kuò)充功能使用 libcurl 發(fā)出 HTTPS 請(qǐng)求,而 libcurl 又使用 OpenSSL 等 TLS 函式庫(kù)來(lái)驗(yàn)證請(qǐng)求。
Curl 擴(kuò)充功能需要一個(gè)包含以下內(nèi)容的有效檔案:所有的 受信任的根證書(shū)來(lái)完成HTTPS驗(yàn)證,以及PHP 將其公開(kāi)為 php.ini 檔案中的指令。
在 Linux、BSD 和 macOS 上,libcurl 可以預(yù)設(shè)為系統(tǒng)根目錄 證書(shū),但這在 Windows 上是不可能的,因?yàn)?Windows 確實(shí) 不附帶包含所有系統(tǒng)根目錄的單一文件 證書(shū)。
本文討論了使用 Curl 擴(kuò)充功能成功發(fā)出 HTTPS 請(qǐng)求的兩種可能方法,以及不採(cǎi)取哪些措施可能導(dǎo)致 HTTPS 請(qǐng)求不安全。
失敗原因
$ch?=?curl_init('https://php.watch');?? curl_setopt($ch,?CURLOPT_RETURNTRANSFER,?true);?? curl_exec($ch);?//?false?? curl_error($ch); //?SSL?certificate?problem:?unable?to?get?local?issuer?certificate
如果curl_exec呼叫失敗並回傳錯(cuò)誤回應(yīng),並且如果curl_error指示SSL憑證問(wèn)題:無(wú)法取得本地頒發(fā)者憑證錯(cuò)誤,這表示Curl未提供包含根證書(shū)的文件,或無(wú)法發(fā)現(xiàn)它。
此錯(cuò)誤在 Linux、BSD 和 macOS 系統(tǒng)上並不常見(jiàn),但相當(dāng)多 Windows上常見(jiàn),因?yàn)闆](méi)有指定檔案取得root 證書(shū),並且 PHP 不在其上提供根證書(shū)列表
解決方案是提供一個(gè)包含最新根目錄的文件 證書(shū),或者理想情況下,讓 Curl 解析本地根存儲(chǔ) 底層作業(yè)系統(tǒng)提供。
使用本機(jī)憑證授權(quán)單位
在 Curl 7.71 及更高版本上,可以設(shè)定 Curl 請(qǐng) Curl 使用本機(jī)(系統(tǒng))根憑證的選項(xiàng)。 這甚至在 Windows 上也有效,其中 Curl 解析系統(tǒng)根證書(shū) 並使用它們。
當(dāng) CURLOPT_SSL_OPTIONS 選項(xiàng)設(shè)定為 CURLSSLOPT_NATIVE_CA 時(shí) 或包含這些位元的位元掩碼,Curl 嘗試使用本機(jī) 根證書(shū)存儲(chǔ),取決於證書(shū)的功能和版本 底層 TLS 庫(kù)。
如果 Curl 擴(kuò)充功能是使用 Curl 7.71 或更高版本以及 PHP 8.2 及更高版本建構(gòu)的,這是建議的修復(fù)。
?$ch?=?curl_init('https://php.watch'); ??curl_setopt($ch,?CURLOPT_RETURNTRANSFER,?true); ???curl_setopt($ch,?CURLOPT_SSL_OPTIONS,?CURLSSLOPT_NATIVE_CA); ????curl_exec($ch);
請(qǐng)注意,上面的程式碼片段不會(huì)檢查Curl 版本和 PHP 版本,並假設(shè)滿足 PHP 和 Curl 版本要求。這 以下是有條件地新增 Curl 選項(xiàng)的範(fàn)例:
$ch?=?curl_init('https://php.watch');?? curl_setopt($ch,?CURLOPT_RETURNTRANSFER,?true);?? if?(defined('CURLSSLOPT_NATIVE_CA')?? ??&&?version_compare(curl_version()['version'],?'7.71',?'>='))?{?? ????curl_setopt($ch,?CURLOPT_SSL_OPTIONS,?CURLSSLOPT_NATIVE_CA); }?? curl_exec($ch);
下載並維護(hù) cacert.pem 檔案
對(duì)於在 8.2 之前的 PHP 版本上執(zhí)行的應(yīng)用程式(其中 CURLSSLOPT_NATIVE_CA 常數(shù)不可用),或當(dāng) Curl 版本低於 7.71 時(shí), 推薦的替代解決方案是下載 Curl 相容的 根證書(shū)文件,並配置 PHP 或 Curl 請(qǐng)求來(lái)使用它。
Curl 項(xiàng)目維護(hù)著最新的證書(shū)清單。請(qǐng)參閱從 Mozilla 提取的 CA 憑證。
下載 cacert.pem 檔案
- 將檔案移至 PHP 和 Web 伺服器可存取的目錄。例如,C:/php/cacert.pem。
編輯 php.ini 檔案並修改curl.cainfo 條目以指向 cacert.pem 檔案的絕對(duì)路徑。
$ch?=?curl_init('https://php.watch');?? curl_setopt($ch,?CURLOPT_RETURNTRANSFER,?true);?? curl_exec($ch);?//?false?? curl_error($ch); //?SSL?certificate?problem:?unable?to?get?local?issuer?certificate
(選用)重新啟動(dòng) Web 伺服器(例如 Apache)以重新載入 INI 檔案。
這種方法的缺點(diǎn)是必須定期更新 cacert.pem 檔案。 cacert.pem 例如,Curl 專案提供的檔案是從根目錄中提取的 由 Mozilla 維護(hù)的商店。平均而言,此列表和文件得到 每年更新4-5次。確保與最新root的兼容性 證書(shū)列表,請(qǐng)確保更新此文件的本機(jī)副本 定期
如果無(wú)法修改INI 文件,請(qǐng)?jiān)贑url 請(qǐng)求中指定cacert.pem 文件的絕對(duì)路徑:
?$ch?=?curl_init('https://php.watch'); ??curl_setopt($ch,?CURLOPT_RETURNTRANSFER,?true); ???curl_setopt($ch,?CURLOPT_SSL_OPTIONS,?CURLSSLOPT_NATIVE_CA); ????curl_exec($ch);
在PHP 8.2 和Curl 7.77 上,可以使用CURLOPT_CAINFO_OB 選項(xiàng)來(lái)取得包含cacert.pem 內(nèi)容的字串。
以上是如何修復(fù) Windows 上的 PHP Curl HTTPS 憑證授權(quán)單位問(wèn)題的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門(mén)文章

熱工具

記事本++7.3.1
好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6
視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版
神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話題

註釋不能馬虎是因?yàn)樗忉尨a存在的原因而非功能,例如兼容老接口或第三方限制,否則看代碼的人只能靠猜。必須加註釋的地方包括複雜的條件判斷、特殊的錯(cuò)誤處理邏輯、臨時(shí)繞過(guò)的限制。寫(xiě)註釋更實(shí)用的方法是根據(jù)場(chǎng)景選擇單行註釋或塊註釋,函數(shù)、類、文件開(kāi)頭用文檔塊註釋說(shuō)明參數(shù)與返回值,並保持註釋更新,對(duì)複雜邏輯可在前面加一行概括整體意圖,同時(shí)不要用註釋封存代碼而應(yīng)使用版本控制工具。

易於效率,啟動(dòng)啟動(dòng)tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)

寫(xiě)好PHP註釋的關(guān)鍵在於清晰、有用且簡(jiǎn)潔。 1.註釋?xiě)?yīng)說(shuō)明代碼背後的意圖而非僅描述代碼本身,如解釋複雜條件判斷的邏輯目的;2.在魔術(shù)值、舊代碼兼容、API接口等關(guān)鍵場(chǎng)景添加註釋以提升可讀性;3.避免重複代碼內(nèi)容,保持簡(jiǎn)潔具體,並使用標(biāo)準(zhǔn)格式如PHPDoc;4.註釋需與代碼同步更新,確保準(zhǔn)確性。好的註釋?xiě)?yīng)站在他人角度思考,降低理解成本,成為代碼的理解導(dǎo)航儀。

PHPblockcommentsareusefulforwritingmulti-lineexplanations,temporarilydisablingcode,andgeneratingdocumentation.Theyshouldnotbenestedorleftunclosed.BlockcommentshelpindocumentingfunctionswithPHPDoc,whichtoolslikePhpStormuseforauto-completionanderrorche

寫(xiě)好註釋的關(guān)鍵在於說(shuō)明“為什麼”而非僅“做了什麼”,提升代碼可讀性。 1.註釋?xiě)?yīng)解釋邏輯原因,例如值選擇或處理方式背後的考量;2.對(duì)複雜邏輯使用段落式註釋,概括函數(shù)或算法的整體思路;3.定期維護(hù)註釋確保與代碼一致,避免誤導(dǎo),必要時(shí)刪除過(guò)時(shí)內(nèi)容;4.在審查代碼時(shí)同步檢查註釋,並通過(guò)文檔記錄公共邏輯以減少代碼註釋負(fù)擔(dān)。

PHP的switch語(yǔ)句適合處理多個(gè)固定值判斷。 1.switch通過(guò)鬆散比較判斷變量值,結(jié)構(gòu)清晰,適用於用戶角色、請(qǐng)求類型、狀態(tài)機(jī)等場(chǎng)景;2.每個(gè)case後應(yīng)加break避免穿透,但也可利用穿透實(shí)現(xiàn)多個(gè)case共享邏輯;3.default可選但建議添加以處理未匹配情況;4.注意類型匹配問(wèn)題,必要時(shí)需手動(dòng)處理類型一致性。

寫(xiě)好PHP註釋的關(guān)鍵在於明確目的與規(guī)範(fàn),註釋?xiě)?yīng)解釋“為什麼”而非“做了什麼”,避免冗餘或過(guò)於簡(jiǎn)單。 1.使用統(tǒng)一格式,如docblock(/*/)用於類、方法說(shuō)明,提升可讀性與工具兼容性;2.強(qiáng)調(diào)邏輯背後的原因,如說(shuō)明為何需手動(dòng)輸出JS跳轉(zhuǎn);3.在復(fù)雜代碼前添加總覽性說(shuō)明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標(biāo)記待辦事項(xiàng)與問(wèn)題,便於後續(xù)追蹤與協(xié)作。好的註釋能降低溝通成本,提升代碼維護(hù)效率。

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre
