0

我们正在使用 cURL 将文件从我们的一台服务器下载到我们的工作流服务器。我正在使用下面粘贴的简单代码,但我的文件“加倍” - 两倍大小,两倍长度。似乎文件已保存,然后再次附加,但我无法弄清楚为什么会发生这种情况。

以下是我的本地机器上的测试代码,其行为方式完全相同:

    $file_name = 'test.mp3';
    $copy_to_dir = 'C:/test_files/';
    $file_url  = 'C:/source_files/test.mp3';

    $fp = fopen ($copy_to_dir. '/' . $file_name, 'w');

    $ch = curl_init($file_url);

    curl_setopt_array($ch, array(
        CURLOPT_URL            => $file_url,
        CURLOPT_RETURNTRANSFER => 1,
        CURLOPT_FILE           => $fp,
        CURLOPT_TIMEOUT        => 50
    ));

    $results = curl_exec($ch);
    if(curl_exec($ch) === false)
    {
      //echo 'Curl error: ' . curl_error($ch);
        return false;
    }

    curl_close($ch);
    fclose($fp);

原文件9MB,每次拷贝18MB

编辑:让这成为你在赶时间时不要复制/粘贴代码的教训,以“节省时间”。第二个 curl_exec() 应该是 curl_errno() 或其他错误处理策略 - 即使只是使用 fwrite() 也意味着我将下载所有内容两次,因此一旦找到解决方法,您就不想退出

4

1 回答 1

0

你打curl_exec()了两次电话,所以它下载了两次文件。改变:

if(curl_exec($ch) === false)

至:

if($results === false)
于 2013-08-15T04:22:39.047 回答