前言
最近在捣鼓命令行下的编程,下载文件总是一个难熬的过程,如果有进度条就好很多了!!!
效果图:
还是挺好看的!
curl有什么用?
用PHP ,curl主要是抓取数据,当然我们可以用其他的方法来抓取,比如fsockopen,file_get_contents等。但是只能抓那些能直接访问的页面,如果要抓取有页面访问控制的页面,或者是登录以后的页面就比较困难了。
curl使用
curl做为 PHP 一个很常用的下载方式,这里简单的使用方式;
上面是一个很简单的例子,如果一个文件很大,那么用户就需要等待很长的时间,这时候我们就应该加上进度条的效果:
function download($url)
{
$ch = curl_init();
// 从配置文件中获取根路径
curl_setopt($ch,$url);
curl_setopt($ch,0);
// 开启进度条
curl_setopt($ch,CURLOPT_NOPROGRESS,0);
// 进度条的触发函数
curl_setopt($ch,CURLOPT_PROGRESSFUNCTION,'progress');
// ps: 如果目标网页跳转,也跟着跳转
// curl_setopt($ch,CURLOPT_FOLLOWLOCATION,true);
if (false === ($stream = curl_exec($ch))) {
throw new \Exception(curl_errno($ch));
}
curl_close($ch);
return $stream;
}
/**
- 进度条下载.
- @param $ch
- @param $countDownloadSize 总下载量
- @param $currentDownloadSize 当前下载量
- @param $countUploadSize
- @param $currentUploadSize
*/
public function progress($ch,$countDownloadSize,$currentDownloadSize,$countUploadSize,$currentUploadSize)
{
// 等于 0 的时候,应该是预读资源不等于0的时候即开始下载
// 这里的每一个判断都是坑,多试试就知道了
if (0 === $countDownloadSize) {
return false;
}
// 有时候会下载两次,第一次很小,应该是重定向下载
if ($countDownloadSize > $currentDownloadSize) {
$this->downloaded = false;
// 继续显示进度条
}
// 已经下载完成还会再发三次请求
elseif ($this->downloaded) {
return false;
}
// 两边相等下载完成并不一定结束,
elseif ($currentDownloadSize === $countDownloadSize) {
return false;
}
// 开始计算
$bar = $currentDownloadSize / $countDownloadSize * 100;
$this->bar->progress($bar);
}
}
(new Request)->download('http://www.shiguopeng.cn/database.sql');
千万千万注意下载回调的判断那里的坑!!!
还有一个问题:如果跳转下载的,设置了curl也跟着跳转,返回的文件将会出问题,
我下载的是zip文件,会导致文件头有第一此请求的HTTP响应头的内容,
所以看自己需要@H_403_42@curl_setopt($ch,true);
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。