无法激活CURLOPT_FOLLOWLOCATION

无法激活CURLOPT_FOLLOWLOCATION,curl,php,Curl,Php,所以我在多台服务器上不断遇到这个恼人的错误(这是一个警告,所以我会忽略它,但我需要这个功能) 警告:curl_setopt() 我将如何通过SSH解决这个问题 在php.ini文件中设置safe_mode=Off(通常在服务器上的/etc/中)。如果已经关闭,那么在php.ini文件中查找open_basedir内容,并相应地更改它 基本上,follow-location选项已经作为一种安全措施被禁用,但是PHP内置的安全特性通常比安全性更令人讨厌。实际上,安全模式简单地说,只要在php.ini

所以我在多台服务器上不断遇到这个恼人的错误(这是一个警告,所以我会忽略它,但我需要这个功能)

警告:curl_setopt()


我将如何通过SSH解决这个问题

在php.ini文件中设置
safe_mode=Off
(通常在服务器上的/etc/中)。如果已经关闭,那么在php.ini文件中查找
open_basedir
内容,并相应地更改它

基本上,follow-location选项已经作为一种安全措施被禁用,但是PHP内置的安全特性通常比安全性更令人讨厌。实际上,
安全模式

简单地说,只要在php.ini文件中启用或,就不能使用CURLOPT\u FOLLOWLOCATION配置。要更改这些设置,我只能给出一般说明:

  • SSH连接到服务器
  • cd到包含php.ini的目录(linux上通常为/etc/php5,具体取决于您的发行版或操作系统)
  • 要编辑的sudo(例如,
    sudo nano php.ini
  • 编辑指定open_basedir或safe_模式的行,并将其关闭

  • 记得在之后重新启动您的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的共享服务器上,则不能使用此选项。