Heim >Backend-Entwicklung >PHP-Tutorial >Wie aktiviere ich Krypto, wenn file_get_contents() mit bestimmten HTTPS-URLs verwendet wird?
Verschlüsselung konnte nicht aktiviert werden, wenn file_get_contents() mit bestimmten HTTPS-URLs verwendet wird
Beim Versuch, Inhalte von bestimmten HTTPS-URLs wie https abzurufen ://eresearch.fidelity.com/, bei Verwendung von file_get_contents() können die folgenden Fehler auftreten:
Warning: file_get_contents(): SSL: crypto enabling timeout Warning: file_get_contents(): Failed to enable crypto Warning: file_get_contents(): failed to open stream: operation failed Fatal error: Maximum execution time of 30 seconds exceeded
Lösung:
Das Problem entsteht durch Zielwebsite unter Verwendung des SSLv3-Protokolls, das von Ihrem PHP-Setup möglicherweise nicht unterstützt wird.
Option 1: Geben Sie die SSL-Version mit cURL an
Erstellen Sie eine Funktion mit cURL:
<code class="php">function getSSLPage($url) { $ch = curl_init(); curl_setopt($ch, CURLOPT_HEADER, false); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSLVERSION,3); // Specify SSL version 3 $result = curl_exec($ch); curl_close($ch); return $result; }</code>
Beispielverwendung:
<code class="php">var_dump(getSSLPage("https://eresearch.fidelity.com/eresearch/evaluate/analystsOpinionsReport.jhtml?symbols=api"));</code>
Option 2: Stammzertifikate in Windows einbeziehen (optional)
In Windows kann es zu einem Mangel kommen des Zugriffs auf Stammzertifikate. Um dieses Problem zu beheben, führen Sie die folgenden Schritte aus:
<code class="php">curl_setopt($ch, CURLOPT_CAINFO, __DIR__ . "/certs/cacert.pem"); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true); // True: verify certificates</code>
Das obige ist der detaillierte Inhalt vonWie aktiviere ich Krypto, wenn file_get_contents() mit bestimmten HTTPS-URLs verwendet wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!