PHP使用CURL实现下载文件功能示例

这篇文章主要介绍了PHP使用CURL实现下载文件功能,结合具体实例形式分析了php基于curl的文件下载实现技巧,代码注释有详细的功能说明,并附带了curl参数的功能讲解,需要的朋友可以参考下。

本文实例讲述了PHP使用CURL实现下载文件功能,分享给大家供大家参考,具体如下:

如果使用CURL下载从微信手机端上传的图片?参考下面代码:

  1. /**
  2. * CURL下载文件 成功返回文件名,失败返回false
  3. * @param $url
  4. * @param string $savePath
  5. * @return bool|string
  6. * @author Zou Yiliang
  7. */
  8. public function downFile($url, $savePath = './uploads')
  9. {
  10. //$url = 'http://www.baidu.com/img/bdlogo.png';
  11. /*
  12. HTTP/1.1 200 OK
  13. Connection: close
  14. Content-Type: image/jpeg
  15. Content-disposition: attachment; filename="cK4q4fLsp7YOlaqxluDOafB.jpg"
  16. Date: Sun, 18 Jan 2015 16:56:32 GMT
  17. Cache-Control: no-cache, must-revalidate
  18. Content-Length: 963704
  19. */
  20. $ch = curl_init();
  21. curl_setopt($ch, CURLOPT_URL, $url);
  22. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  23. curl_setopt($ch, CURLOPT_HEADER, TRUE); //需要response header
  24. curl_setopt($ch, CURLOPT_NOBODY, FALSE); //需要response body
  25. $response = curl_exec($ch);
  26. //分离header与body
  27. $header = '';
  28. $body = '';
  29. if (curl_getinfo($ch, CURLINFO_HTTP_CODE) == '200') {
  30. $headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE); //头信息size
  31. $header = substr($response, 0, $headerSize);
  32. $body = substr($response, $headerSize);
  33. }
  34. curl_close($ch);
  35. //文件名
  36. $arr = array();
  37. if (preg_match('/filename="(.*?)"/', $header, $arr)) {
  38. $file = date('Ym') . '/' . $arr[1];
  39. $fullName = rtrim($savePath, '/') . '/' . $file;
  40. //创建目录并设置权限
  41. $basePath = dirname($fullName);
  42. if (!file_exists($basePath)) {
  43. @mkdir($basePath, 0777, true);
  44. @chmod($basePath, 0777);
  45. }
  46. if (file_put_contents($fullName, $body)) {
  47. return $file;
  48. }
  49. }
  50. return false;
  51. }

附:常用CURL选项说明

CURLOPT_AUTOREFERER

当根据Location:重定向时,自动设置header中的Referer:信息。

CURLOPT_BINARYTRANSFER

在启用CURLOPT_RETURNTRANSFER的时候,返回原生的(Raw)输出。

CURLOPT_COOKIESESSION

启用时curl会仅仅传递一个session cookie,忽略其他的cookie,默认状况下cURL会将所有的cookie返回给服务端。session cookie是指那些用来判断服务器端的session是否有效而存在的cookie。

CURLOPT_CRLF

启用时将Unix的换行符转换成回车换行符。

CURLOPT_DNS_USE_GLOBAL_CACHE

启用时会启用一个全局的DNS缓存,此项为线程安全的,并且默认启用。

CURLOPT_FAILONERROR

显示HTTP状态码,默认行为是忽略编号小于等于400的HTTP信息。

CURLOPT_FILETIME

启用时会尝试修改远程文档中的信息。结果信息会通过 curl_getinfo()函数的CURLINFO_FILETIME选项返回。curl_getinfo().

CURLOPT_FOLLOWLOCATION

启用时会将服务器服务器返回的"Location: "放在header中递归的返回给服务器,使用CURLOPT_MAXREDIRS可以限定递归返回的数量。

CURLOPT_FORBID_REUSE

在完成交互以后强迫断开连接,不能重用。

CURLOPT_FRESH_CONNECT

强制获取一个新的连接,替代缓存中的连接。

CURLOPT_FTP_USE_EPRT

启用时当FTP下载时,使用EPRT (或 LPRT)命令。设置为FALSE时禁用EPRT和LPRT,使用PORT命令 only.

CURLOPT_FTP_USE_EPSV

启用时,在FTP传输过程中回复到PASV模式前首先尝试EPSV命令。设置为FALSE时禁用EPSV命令。

CURLOPT_FTPAPPEND

启用时追加写入文件而不是覆盖它。

CURLOPT_FTPASCII

CURLOPT_TRANSFERTEXT的别名。

CURLOPT_FTPLISTONLY

启用时只列出FTP目录的名字。

CURLOPT_HEADER

启用时会将头文件的信息作为数据流输出。

CURLINFO_HEADER_OUT

启用时追踪句柄的请求字符串。

从 PHP 5.1.3 开始可用。CURLINFO_前缀是故意的(intentional)。

CURLOPT_HTTPGET

启用时会设置HTTP的method为GET,因为GET是默认是,所以只在被修改的情况下使用。

CURLOPT_HTTPPROXYTUNNEL

启用时会通过HTTP代理来传输。

CURLOPT_MUTE

启用时将cURL函数中所有修改过的参数恢复默认值。

CURLOPT_NETRC

在连接建立以后,访问~/.netrc文件获取用户名和密码信息连接远程站点。

CURLOPT_NOBODY

启用时将不对HTML中的BODY部分进行输出。

CURLOPT_NOPROGRESS

启用时关闭curl传输的进度条,此项的默认设置为启用。

Note:

PHP自动地设置这个选项为TRUE,这个选项仅仅应当在以调试为目的时被改变。

CURLOPT_NOSIGNAL

启用时忽略所有的curl传递给php进行的信号。在SAPI多线程传输时此项被默认启用。

cURL 7.10时被加入。

CURLOPT_POST

启用时会发送一个常规的POST请求,类型为:application/x-www-form-urlencoded,就像表单提交的一样。

CURLOPT_PUT

启用时允许HTTP发送文件,必须同时设置CURLOPT_INFILE和CURLOPT_INFILESIZE。

CURLOPT_RETURNTRANSFER

将 curl_exec()获取的信息以文件流的形式返回,而不是直接输出。

CURLOPT_SSL_VERIFYPEER

禁用后cURL将终止从服务端进行验证。使用CURLOPT_CAINFO选项设置证书使用CURLOPT_CAPATH选项设置证书目录 如果CURLOPT_SSL_VERIFYPEER(默认值为2)被启用,CURLOPT_SSL_VERIFYHOST需要被设置成TRUE否则设置为FALSE。

自cURL 7.10开始默认为TRUE。从cURL 7.10开始默认绑定安装。

CURLOPT_TRANSFERTEXT

启用后对FTP传输使用ASCII模式。对于LDAP,它检索纯文本信息而非HTML。在Windows系统上,系统不会把STDOUT设置成binary模式。

CURLOPT_UNRESTRICTED_AUTH

在使用CURLOPT_FOLLOWLOCATION产生的header中的多个locations中持续追加用户名和密码信息,即使域名已发生改变。

CURLOPT_UPLOAD

启用后允许文件上传。

CURLOPT_VERBOSE

启用时会汇报所有的信息,存放在STDERR或指定的CURLOPT_STDERR中。