Deprecated
: htmlspecialchars(): Passing null to parameter #1 ($string) of type string is deprecated in
/www/wwwroot/testblog.58heshihu.com/var/Widget/Archive.php
on line
1057
首页
关于
Search
1
给你10个市场数据调研报告的免费下载网站!以后竞品数据就从这里找!
182 阅读
2
php接口优化 使用curl_multi_init批量请求
144 阅读
3
《从菜鸟到大师之路 ElasticSearch 篇》
107 阅读
4
2024年备考系统架构设计师
104 阅读
5
PHP 文件I/O
92 阅读
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
登录
Search
标签搜索
php函数
php语法
性能优化
安全
错误和异常处理
问题
vue
Composer
Session
缓存
框架
Swoole
api
并发
异步
正则表达式
php-fpm
mysql 索引
开发规范
协程
dafenqi
累计撰写
786
篇文章
累计收到
28
条评论
首页
栏目
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
副业
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
页面
关于
搜索到
2
篇与
的结果
2023-08-10
PHP实现文件断点续传下载
PHP实现文件断点续传下载<?php //PHP 断点续传下载 function download($fileurl, $start = 0, $end = '') { $task_sourcefile = '/path/downfile.mp4'; //本地保存的文件 $sourceurl = $fileurl ; //要下载的远程文件 $tokenfile = 'downfile.token'; $isfileexist =$this->check_remote_file_exists($sourceurl); if (!$isfileexist) { $isfileexist2 =$this->check_remote_file_exists($sourceurl); if (!$isfileexist2) { throw new \Exception('远程文件不存在'); } } if (!is_dir(dirname($tokenfile))) { mkdir(dirname($tokenfile), 0777, true); } $sourcefilepath = dirname($task_sourcefile); if (!is_dir($sourcefilepath)) { @mkdir($sourcefilepath, 0777, true); } $ch = curl_init($sourceurl); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_BINARYTRANSFER, true); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_USERAGENT, 'SyncTask'); curl_setopt($ch, CURLOPT_NOSIGNAL, 1); //注意,超时一定要设置这个 curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_DNS_CACHE_TIMEOUT, 3600); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 300); curl_setopt($ch, CURLOPT_TIMEOUT, 600); //此选项,是下载超时时间,时间设置短的话,没有下载完,就会断开连接,然后再重新断点续传下载。如果设置过长,可能会发生由于网络原因产生的下载长时间卡住 的现象。请设置合理值。建议不要设置太长。 //curl_setopt($ch, CURLOPT_TIMEOUT_MS, 100 * 1000); //超时毫秒 curl_setopt($ch, CURLOPT_BUFFERSIZE, 20971520); if ($end) { curl_setopt($ch, CURLOPT_RANGE, "$start-$end"); } else { curl_setopt($ch, CURLOPT_RANGE, "$start-"); } $flag=$tag = 0; curl_setopt($ch, CURLOPT_WRITEFUNCTION, function ($ch, $str) use (&$flag, $task_sourcefile, $end, $sourceurl, $tokenfile, $start, &$tag) { $len = strlen($str); $flag++; if ($flag==1) { $httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE); $length = curl_getinfo($ch, CURLINFO_CONTENT_LENGTH_DOWNLOAD); if ($length ==-1) { $tag = 2; return false; } if ($httpcode!=200 && $httpcode!=206) { $tag = 2; return false; } if ($start ==0) { $data= ['name'=>$sourceurl,'size'=>$length]; file_put_contents($tokenfile, <a class="wpal-linked-keyword" href="http://json.p2hp.com/" target="_blank">json</a>_encode($data, JSON_UNESCAPED_UNICODE)); } if ($end) { if ($end-$start!=$length) { $tag = 1; return false; } } } file_put_contents($task_sourcefile, $str, FILE_APPEND|LOCK_EX); return $len; }); $output = curl_exec($ch); if ($tag ==2 || $output===false) { curl_close($ch); clearstatcache(); download($fileurl, filesize($task_sourcefile), ''); } if ($tag ==1) { unlink($task_sourcefile); unlink($tokenfile); curl_close($ch); download($fileurl, 0, ''); return true; } $tokeninfo = json_decode(file_get_contents($tokenfile), true); $length = $tokeninfo['size']; sleep(1); clearstatcache();//这里要去除文件信息缓存 if ($length!= filesize($task_sourcefile)) { curl_close($ch); echo '下载出错:长度不长度不匹配~~'; clearstatcache(); download($fileurl, filesize($task_sourcefile), ''); } curl_close($ch); return true; } //run $download= download('http://www.test.com/333.mp4'); var_dump($download);
2023年08月10日
8 阅读
0 评论
0 点赞
2023-08-04
让PHP更快的提供文件下载
让PHP更快的提供文件下载一般来说, 我们可以通过直接让URL指向一个位于Document Root下面的文件, 来引导用户下载文件.但是, 这样做, 就没办法做一些统计, 权限检查, 等等的工作. 于是, 很多时候, 我们采用让PHP来做转发, 为用户提供文件下载.<?php$file = "/tmp/dummy.tar.gz"; header("Content-type: application/octet-stream"); header('Content-Disposition: attachment; filename="' . basename($file) . '"'); header("Content-Length: ". filesize($file)); readfile($file);但是这个有一个问题, 就是如果文件是中文名的话, 有的用户可能下载后的文件名是乱码.于是, 我们做一下修改(参考: :<?php$file = "/tmp/中文名.tar.gz"; $filename = basename($file); header("Content-type: application/octet-stream"); //处理中文文件名 $ua = $_SERVER["HTTP_USER_AGENT"]; $encoded_filename = urlencode($filename); $encoded_filename = str_replace("+", "%20", $encoded_filename); if (preg_match("/MSIE/", $ua)) { header('Content-Disposition: attachment; filename="' . $encoded_filename . '"'); } else if (preg_match("/Firefox/", $ua)) { header("Content-Disposition: attachment; filename*=\"utf8''" . $filename . '"'); } else { header('Content-Disposition: attachment; filename="' . $filename . '"'); } header('Content-Disposition: attachment; filename="' . $filename . '"'); header("Content-Length: ". filesize($file)); readfile($file);恩, 现在看起来好多了, 不过还有一个问题, 那就是readfile, 虽然PHP的readfile尝试实现的尽量高效, 不占用PHP本身的内存, 但是实际上它还是需要采用MMAP(如果支持), 或者是一个固定的buffer去循环读取文件, 直接输出.输出的时候, 如果是Apache + PHP mod, 那么还需要发送到Apache的输出缓冲区. 最后才发送给用户. 而对于Nginx + fpm如果他们分开部署的话, 那还会带来额外的网络IO.那么, 能不能不经过PHP这层, 直接让Webserver直接把文件发送给用户呢?今天, 我看到了一个有意思的文章: How I PHP: X-SendFile.我们可以使用Apache的module mod_xsendfile, 让Apache直接发送这个文件给用户:<?php$file = "/tmp/中文名.tar.gz"; $filename = basename($file); header("Content-type: application/octet-stream"); //处理中文文件名 $ua = $_SERVER["HTTP_USER_AGENT"]; $encoded_filename = urlencode($filename); $encoded_filename = str_replace("+", "%20", $encoded_filename); if (preg_match("/MSIE/", $ua)) { header('Content-Disposition: attachment; filename="' . $encoded_filename . '"'); } else if (preg_match("/Firefox/", $ua)) { header("Content-Disposition: attachment; filename*=\"utf8''" . $filename . '"'); } else { header('Content-Disposition: attachment; filename="' . $filename . '"'); } header('Content-Disposition: attachment; filename="' . basename($file) . '"'); //让Xsendfile发送文件 header("X-Sendfile: $file");X-Sendfile头将被Apache处理, 并且把响应的文件直接发送给Client.Lighttpd和Nginx也有类似的模块, 大家有兴趣的可以去找找看 :)
2023年08月04日
22 阅读
0 评论
0 点赞