php 抓取HTTPS內容和錯誤處理的方法範例程式碼

怪我咯
發布: 2023-03-12 22:58:01
原創
915 人瀏覽過

這篇文章主要介紹了PHP抓取HTTPS內容的實作方法,以及在抓取的時候遇到的一個HTTPS問題的處理辦法,有需要的朋友們可以參考借鑒,下面來一起看看吧。

問題

在研究Hacker News API的時候遇到一個HTTPS問題。因為所有的Hacker News API都是透過加密的HTTPS協定存取的,跟普通的HTTP協定不同,當使用PHP裡的函數<a href="http://www.php.cn/wiki/1311.html" target="_blank">file_get_contents</a>() 來取得API裡提供的資料時,出現錯誤

使用的程式碼是這樣的:

#
<?php
$data = file_get_contents("/http://blog.it985.com/");
?>
登入後複製

當執行上面的程式碼是遇到下面的錯誤提示:

PHP Warning: file_get_contents(): Unable to find the wrapper “https” – did you forget to enable it when you configured PHP?
登入後複製

為什麼會出現這樣的錯誤?

在網路上經過一番搜索,發現遇到這樣錯誤的人還不少,問題很直接,是因為在PHP的設定檔裡沒有開啟一個參數,在我本機上是/apache/bin/php.ini 裡的 ;extension=php_openssl.dll 這一項,需要將前面的分號去掉。

你可以用下面的腳本來檢查你的PHP環境的配置:

<?php
$w = stream_get_wrappers();
echo &#39;openssl: &#39;, extension_loaded (&#39;openssl&#39;) ? &#39;yes&#39;:&#39;no&#39;, "\n";
echo &#39;http wrapper: &#39;, in_array(&#39;http&#39;, $w) ? &#39;yes&#39;:&#39;no&#39;, "\n";
echo &#39;https wrapper: &#39;, in_array(&#39;https&#39;, $w) ? &#39;yes&#39;:&#39;no&#39;, "\n";
echo &#39;wrappers: &#39;, var_dump($w);
登入後複製

運行上面的這個腳本片段,在我的機器上得到的結果是:

<?php
openssl: no
http wrapper: yes
https wrapper: no
wrappers: array(10) {
[0]=>
string(3) "php"
[1]=>
string(4) "file"
[2]=>
string(4) "glob"
[3]=>
string(4) "data"
[4]=>
string(4) "http"
[5]=>
string(3) "ftp"
[6]=>
string(3) "zip"
[7]=>
string(13) "compress.zlib"
[8]=>
string(14) "compress.bzip2"
[9]=>
string(4) "phar"
}
登入後複製

替代方案

發現錯誤,修正錯誤,這很簡單,困難的是,發現錯誤後無法改正錯誤。我原本是想將這個腳本方法遠端主機上,但我無法修改遠端主機的PHP配置,結果是,我無法使用這一方案,但我們不能在一棵樹上吊死,這條路走不通,看看有沒有其它路。

另外一個我常用的PHP裡抓取內容的函數是 curl ,它比 file_get_contents() 更強大,提供了很多的可選參數。對於存取 HTTPS 內容的問題,我們需要使用的 CURL 設定參數是:

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
登入後複製

你可以從語意看出,它是忽略/跳過了SSL安全驗證。也許這不是一個很好的做法,但對於普通的場景中,這幾經足夠了。

以下是利用 Curl 封裝的一個能存取HTTPS內容的函數:

function getHTTPS($url) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_REFERER, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
$result = curl_exec($ch);
curl_close($ch);
return $result;
}
登入後複製

以上是php 抓取HTTPS內容和錯誤處理的方法範例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!