无法激活CURLOPT_FOLLOWLOCATION
所以我在多台服务器上不断遇到这个恼人的错误(这是一个警告,所以我会忽略它,但我需要这个功能) 警告:curl_setopt()无法激活CURLOPT_FOLLOWLOCATION,curl,php,Curl,Php,所以我在多台服务器上不断遇到这个恼人的错误(这是一个警告,所以我会忽略它,但我需要这个功能) 警告:curl_setopt() 我将如何通过SSH解决这个问题 在php.ini文件中设置safe_mode=Off(通常在服务器上的/etc/中)。如果已经关闭,那么在php.ini文件中查找open_basedir内容,并相应地更改它 基本上,follow-location选项已经作为一种安全措施被禁用,但是PHP内置的安全特性通常比安全性更令人讨厌。实际上,安全模式简单地说,只要在php.ini
我将如何通过SSH解决这个问题 在php.ini文件中设置
safe_mode=Off
(通常在服务器上的/etc/中)。如果已经关闭,那么在php.ini文件中查找open_basedir
内容,并相应地更改它
基本上,follow-location选项已经作为一种安全措施被禁用,但是PHP内置的安全特性通常比安全性更令人讨厌。实际上,安全模式
简单地说,只要在php.ini文件中启用或,就不能使用CURLOPT\u FOLLOWLOCATION配置。要更改这些设置,我只能给出一般说明:
sudo nano php.ini
)记得在之后重新启动您的httpd 关于安全模式和打开\u basedir选项:
试试这个,如果需要重定向并且启用了安全模式,它将根据标题跟随链接(如果你抓取图像,尽管这在将标题添加到返回中时不起作用),这是针对你的特定问题的解决方法,当客户安装了我的一个脚本时,我也遇到了同样的问题,因此不得不想出这个方法。。它还将把错误记录到:
curl.error.log
。。有用吗
<?php
function geturl($url) {
(function_exists('curl_init')) ? '' : die('cURL Must be installed for geturl function to work. Ask your host to enable it or uncomment extension=php_curl.dll in php.ini');
$curl = curl_init();
$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,";
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5";
$header[] = "Cache-Control: max-age=0";
$header[] = "Connection: keep-alive";
$header[] = "Keep-Alive: 300";
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7";
$header[] = "Accept-Language: en-us,en;q=0.5";
$header[] = "Pragma: ";
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 5.1; rv:5.0) Gecko/20100101 Firefox/5.0 Firefox/5.0');
curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
curl_setopt($curl, CURLOPT_HEADER, true);
curl_setopt($curl, CURLOPT_REFERER, $url);
curl_setopt($curl, CURLOPT_ENCODING, 'gzip,deflate');
curl_setopt($curl, CURLOPT_AUTOREFERER, true);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
//curl_setopt($curl, CURLOPT_FOLLOWLOCATION, true); //CURLOPT_FOLLOWLOCATION Disabled...
curl_setopt($curl, CURLOPT_TIMEOUT, 60);
$html = curl_exec($curl);
$status = curl_getinfo($curl);
curl_close($curl);
if ($status['http_code'] != 200) {
if ($status['http_code'] == 301 || $status['http_code'] == 302) {
list($header) = explode("\r\n\r\n", $html, 2);
$matches = array();
preg_match("/(Location:|URI:)[^(\n)]*/", $header, $matches);
$url = trim(str_replace($matches[1],"",$matches[0]));
$url_parsed = parse_url($url);
return isset($url_parsed) ? geturl($url) : '';
}
$oline='';
foreach ($status as $key => $eline) {
$oline .= '['.$key.']'.$eline.' ';
}
$line = $oline." \r\n ".$url."\r\n-----------------\r\n";
$handle = @fopen('./curl.error.log', 'a');
fwrite($handle, $line);
return false;
}
return $html;
}
要解决这个问题,只需关闭safe_mode=Off
并清除php.ini文件中的open_base_dir
。您的设置是什么(启用了safe mode和/或open basedir?)以及您试图实现什么?@Flambine:debricated意味着它仍然存在并按预期工作,但这是非常不鼓励的。它可以而且经常在较旧的共享主机平台上启用。我同意“安全模式”充其量也很烦人。@Wrikken:你说得对,对不起。但我相信,在PHP6中,安全模式将完全消失。现在没什么帮助了。不过,我还是混淆了这两个问题。顺便说一下:根据PHP5.4中删除的安全模式,如果您使用的是共享服务器,则无法修改PHP.ini,还有其他解决方案吗?@JosephAstrahan举个例子,我会说找一个更好的主机提供商。但是有一个可能的解决办法。不知道它是否有效,尽管您“可能”不想添加一个检查,以确保新url不是文件://url。可能会暴露出“file:///myproject/database.php自7.19.4起,cURL默认不允许使用的“等”(参见CULLOPT_REDIR_协议)。较低版本的curl没有该限制,这就是为什么在安全模式下不允许CURLOPT_FOLLOWLOCATION。未定义变量:referer@2astalavista谢谢fixedNice,我一直在谷歌上搜索这样一个解决方案!非常感谢你这么做。我试图使用and//curl\u setopt($curl,CURLOPT\u FOLLOWLOCATION,true)//CURLOPT_FOLLOWLOCATION已禁用…
是服务器上的一种方式。如果您位于无法访问php.ini的共享服务器上,则不能使用此选项。