Baidu をクロールするには、curl_setopt を使用します。Baidu 画像の盗難を防ぐ最善の方法は何ですか?
$url = "http://www.baidu.com/s?wd=csdn";<br />$header = array (<br /> 'User-Agent: Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36'<br />);<br />$ch = curl_init ();<br />$timeout = 10; <br />curl_setopt ( $ch, CURLOPT_URL, $url );<br />curl_setopt ( $ch, CURLOPT_HTTPHEADER, $header );<br />curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );<br />curl_setopt ( $ch, CURLOPT_CONNECTTIMEOUT,$timeout);<br /><br />$content = curl_exec ( $ch );<br />if ($content == FALSE) {<br /> echo "error:" . curl_error ( $ch );<br />}<br /><br />curl_close ( $ch );<br />echo $content;
ログイン後にコピー
-----ソリューションアイデア--------------------- -偽のリファラー URL
-----ソリューションのアイデア----------------------一階はとても分かりやすくなりました。
------解決策のアイデア----------------------写真を見せるときはそれを理解する必要があります、これは PHP からの CURL リクエストではなく、ブラウザからのリクエストです。ブラウザーによって送信されたリクエスト、現在の URL のドメイン名 (www.devtest.com など)、画像のリファラーは何か。したがって、写真は絶対に見えません。
1 つの方法は、すべての Baidu 画像を自分で作成した php (url/image.php?baidu_url=****** など) に置き換えることです。***** は実際の画像のアドレスです。 image.php は、curl を呼び出し、それをフェッチするための参照を追加します。
------ソリューションのアイデア----------------------http://i7.baidu. com/it/u=1366412274,1504179524&fm=96&s=E840F41219BFE0C844FC8DCA0300F0B3
コードを使用して直接アクセスすることはできません (403 エラー)
ただし、コードを持って http://www.baidu.com/s? にアクセスすることはできます。 wd =csdn 取得した Cookie には、コード
を使用してアクセスできます。