简体   繁体   中英

Grabbing CSV over cURL in PHP

Unfortunately, I cannot use either fopen or file_get_contents, so my working script has become a broken one using cURL:

$ch = curl_init();
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$tmp = curl_exec($ch);
curl_close($ch);
header("Content-type: application/csv");
header(Content-Disposition: attachment; filename=$start.csv");
header("Pragma: no-cache");
header("Expires: 0");
echo $tmp;

URL going in is a CSV file - and the fopen version of this worked before. All I get is an empty CSV file returned to the browser.

Thanks.

By default curl_exec returns a boolean. You need to set the CURLOPT_RETURNTRANSFER option to 1 or true to get the transfer payload returned.

Ok there could be a couple of places which went wrong, most likely the $tmp variable will be your key.

I am assuming the $url and $start variables have been declared correctly

First thing I would suggest is to do something along the lines of:

    if( ! $tmp = curl_exec($ch))
        {
           echo curl_error($ch);
        } 

    else
    {

        header("Content-type: application/csv");
        header("Content-Disposition: attachment; filename=$start.csv");
        header("Pragma: no-cache");
        header("Expires: 0");
        echo $tmp;
    }
    curl_close($ch);

Might give you an idea about what is going wrong

Set CURLOPT_RETURNTRANSFER to 1 so you get something into $tmp, otherwise curl_exec outputs the csv directly (and before you send the headers). See http://www.php.net/manual/en/function.curl-setopt.php

我相信除非您先使用curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)否则curl_exec($ch)不会返回字符串。

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM