In diesem Artikel wird hauptsächlich die Implementierung von PHP zum Erfassen von HTTPS-Inhalten sowie Lösungen für die aufgetretenen Probleme vorgestellt.
Ich bin kürzlich beim Studium der Hacker News API auf ein HTTPS-Problem gestoßen . Da auf alle Hacker News-APIs über das verschlüsselte HTTPS-Protokoll zugegriffen wird, das sich vom normalen HTTP-Protokoll unterscheidet, tritt bei Verwendung der Funktion <a href="http://www.php.cn/wiki/1311.html" target="_blank">file_get_contents</a>()
in PHP zum Abrufen der in der API bereitgestellten Daten ein Fehler auf. Der verwendete Code lautet wie folgt :
<?php $data = file_get_contents("https://hacker-news.firebaseio.com/v0/topstories.json?print=pretty"); ......
Beim Ausführen des obigen Codes wird die folgende Fehlermeldung angezeigt:
PHP Warning: file_get_contents(): Unable to find the wrapper "https" - did you forget to enable it when you configured PHP?
Das Folgende ist ein Screenshot:
Warum tritt dieser Fehler auf?
Nachdem ich im Internet gesucht habe, habe ich festgestellt, dass viele Leute auf diesen Fehler gestoßen sind. Das Problem ist sehr direkt, da in der Konfigurationsdatei von PHP kein Parameter aktiviert ist Auf dem lokalen Computer handelt es sich um das Element /apache/bin/php.ini
in ;extension=php_openssl.dll
, und das vorangehende Semikolon muss entfernt werden. Sie können das folgende Skript verwenden, um die Konfiguration Ihrer PHP-Umgebung zu überprüfen:
$w = stream_get_wrappers(); echo 'openssl: ', extension_loaded ('openssl') ? 'yes':'no', "\n"; echo 'http wrapper: ', in_array('http', $w) ? 'yes':'no', "\n"; echo 'https wrapper: ', in_array('https', $w) ? 'yes':'no', "\n"; echo 'wrappers: ', var_dump($w);
Wenn Sie den obigen Skriptausschnitt ausführen, ist das Ergebnis auf meinem Computer:
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" }
Alternativen
Finden Sie den Fehler und beheben Sie ihn. Das Schwierige ist, dass Sie den Fehler nicht beheben können, nachdem Sie ihn gefunden haben. Ich wollte diese Skriptmethode ursprünglich auf dem Remote-Host installieren, konnte aber die PHP-Konfiguration des Remote-Hosts nicht ändern. Das Ergebnis war, dass ich diese Lösung nicht verwenden konnte, aber wir können uns nicht an einen Baum hängen. Dieser Weg funktioniert nicht. Gibt es einen anderen Weg?
Eine weitere Funktion, die ich häufig zum Erfassen von Inhalten in PHP verwende, ist curl
. Sie ist leistungsfähiger als file_get_contents()
und bietet viele optionale Parameter. Für das Problem des Zugriffs auf HTTPS
-Inhalte müssen wir folgende CURL
-Konfigurationsparameter verwenden:
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
Sie können an der Semantik erkennen, dass die SSL-Sicherheitsüberprüfung ignoriert/übersprungen wird. Vielleicht ist das keine gute Idee, aber für gewöhnliche Szenarien reicht es aus.
Das Folgende ist eine von Curl
gekapselte Funktion, die auf HTTPS-Inhalte zugreifen kann:
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; }
Das Obige ist der gesamte Prozess zum Abrufen von https-Inhalten in PHP. Es ist sehr einfach und praktisch . Es wird allen Freunden empfohlen, die die gleichen Projektbedürfnisse haben.
Das obige ist der detaillierte Inhalt vonPHP-Codebeispiel zum Erfassen von HTTPS-Inhalten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!