phpのcurlを使用してリモートファイルを取得する場合、コードは次のとおりです:
コードをコピーします コードは次のとおりです:
<
$ghurl = isset($_GET['id']) ? $_GET['id' ]:'http://www.baidu.com/';
// php get
function getContents($url){
$header = array("参照元: http://www. baidu.com/");
$ch =curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_TIMEOUT, 30);
curl_setopt($ch, CURLOPT_HTTPHEADER,$header);
curl_setopt($ch, CURLOPT_FO LLOWLOCATION ,1); //ジャンプ後にページをクロールするかどうか
curl_exec($ch); $ch);
return $contents;
$contents($ghurl);
通常、win2003+iis では問題ありません。 php_curl.dllが設定されています。
しかし、作者は linux+apahe2.0+php5.2.12+directadmin を使用しています (通常、外国のホスティング会社はこの構成を使用します) 取得した URL に 301/302 ジャンプがある場合、エラーが報告されます:
curl_setopt() [ function.curl -setopt]:safe_mode または open_basedir が *** に設定されている場合、CURLOPT_FOLLOWLOCATION をアクティブにすることはできません
この問題に関して、Google、Baidu はすべて長い英語で、熟練していない人にとっては本当に頭の痛い問題です。 Linuxでは。
解決策は実際には非常に簡単です: 直接管理者にログインします
検索 ->>「PHP セーフモード構成」 -->>下の図を参照してください
デフォルトの
Default Safe
と
Default Open BaseDir
を両方
オフにすると、問題は解決されます。
http://www.bkjia.com/PHPjc/323411.htmlwww.bkjia.com
true
http://www.bkjia.com/PHPjc/323411.html
技術記事 PHP のカールを使用してリモート ファイルを取得する場合、コードは次のようになります。 $ghurl = isset($_GET['id']) $_GET['id']:'http://www .baidu.com /' // php 関数 getCon を取得します...