提供されている cURL 関数は、Web ページを取得するための優れたツールです。ただし、HTTPS URL を扱う場合には課題が発生します。この問題を解決するには、cURL で使用されるオプション配列に SSL 証明書の検証を組み込む必要があります。
デフォルトでは、cURL はリモート サーバーの SSL 証明書を検証して、安全な接続を確保します。ただし、現在のコードにはこの検証が欠けているため、中間者攻撃の影響を受けやすくなっています。 SSL 証明書の検証を無効にして HTTPS サポートを有効にするには、次の行をオプション配列に追加します:
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
または、これを get_web_page() 関数に直接統合できます:
function get_web_page($url) { $options = array( CURLOPT_RETURNTRANSFER => true, CURLOPT_HEADER => false, CURLOPT_FOLLOWLOCATION => true, CURLOPT_ENCODING => "", CURLOPT_USERAGENT => "spider", CURLOPT_AUTOREFERER => true, CURLOPT_CONNECTTIMEOUT => 120, CURLOPT_TIMEOUT => 120, CURLOPT_MAXREDIRS => 10, CURLOPT_SSL_VERIFYPEER => false // Disable SSL Cert checks ); // ... code continues as before ... }
この追加により、SSL 証明書の検証が無効になり、cURL が HTTPS URL からデータを取得できるようになります。ただし、これはセキュリティ面を損なうため、運用環境での使用は通常推奨されないことに注意することが重要です。より堅牢な HTTPS サポートを実現するには、適切な SSL 検証メカニズムの実装を検討してください。
以上がPHP cURL で HTTPS URL を処理し、SSL 証明書検証を安全に管理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。