php下载远程文件的源码介绍
本篇文章给大家带来的内容是关于php下载远程文件的源码介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
最近遇到下载pdf格式的文件存在问题 下载后看不了还有下载不了的问题
大致思路是将文件先从远程下载后 再读取下载到用户本地电脑 再将文件删除 不多说了 直接贴源码
远程文件的命名 最好使用英文数字组合 ,不要用中文命名 总会遇到你想不到的问题
里面也包括压缩下载 具体 大家看源码 研究吧
<?php set_time_limit(0); //允许下载的url $allowed_url = [ '', '', '']; // 允许的url //$file_urls = post('file_urls'); $file_urls = '';//远程文件路径 $file_url_arr = explode(',', $file_urls); $file_url_arr = array_unique($file_url_arr); // 过滤相同url //foreach ($file_url_arr as $key => $val) { // $url_arr = parse_url($val); // if (!isset($url_arr['host']) || !in_array($url_arr['host'], $allowed_url)) { // unset($file_url_arr[$key]); // } //} if (empty($file_url_arr)) { $output = array( 'status' => 2, 'code' => 999, 'error' => '未找到合法url', ); exit(json_encode($output)); } $download_dir = ROOT.'download'.DIRECTORY_SEPARATOR; if(!file_exists($download_dir)) mkdir($download_dir, 0777, true); $tmp_dir = $download_dir.time().rand(100, 999).DIRECTORY_SEPARATOR; // 文件临时存放目录 $downloader = new fileDownloader(); if($file_url_arr && !empty($file_url_arr)) $downloader->download($tmp_dir, $file_url_arr); // 下载文件 $file_lists = scandir($tmp_dir); $file_lists = array_diff($file_lists, ['.', '..']); $file_lists = array_values($file_lists); // 重置索引 if(empty($file_lists)){ $output = array( 'status' => 2, 'code' => 999, 'error' => '无下载文件', ); exit(json_encode($output)); } //if (count($file_lists) > 1) { // 如果是多个文件就压缩 // $file_name = $downloader->compress($tmp_dir, $subject_title); //} else { $file_name = $file_lists[0]; // 如果是单个文件就直接输出 //} $file_headers = get_headers($file_urls, 1); header("Cache-Control: public"); header("Content-Description: File Transfer"); //header('Content-disposition: attachment; filename='.basename($file_name)); //文件名 header('Content-Type: '.$file_headers['Content-Type']); //zip header("Content-Transfer-Encoding: binary"); //二进制文件 header('Content-Length: '. filesize($tmp_dir.$file_name)); //文件大小 $user_agent = $_SERVER["HTTP_USER_AGENT"]; $encoded_name = rawurlencode($file_name); if (preg_match("/Firefox/", $user_agent)) { //火狐浏览器 header('Content-Disposition: attachment; filename*=utf-8\'\''.$encoded_name); } else { // IE, 谷歌浏览器 header('Content-Disposition: attachment; filename="' . $file_name . '"'); } ob_clean(); flush(); @readfile($tmp_dir.$file_name); $downloader->deleteDir($tmp_dir); //文件下载类 class fileDownloader{ // 下载文件 // $dir 文件存放地址,绝对路径 // $urls 文件下载地址 public function download($dir, $urls = array()){ if (!file_exists($dir)) { mkdir($dir, 0777, true); } if (empty($urls)) { return; } foreach ($urls as $val) { $file_name_arr = explode('/', $val); // 使用 / 分隔url $file_name = array_pop($file_name_arr); // 弹出数组的最后一个元素,作为文件名 // 如果以linux作为主机,需要将utf文件名转换成GBK文件名 // if (PHP_OS != 'WINNT') { // $file_name = mb_convert_encoding($file_name, 'gbk', 'utf-8'); // 把文件名从utf-8转换为gbk // } // $file_name = mb_convert_encoding($file_name, 'gbk', 'utf-8'); // 把文件名从utf-8转换为gbk // 下载文件 $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$val); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 0); $data = curl_exec($ch); error_log(var_export(curl_getinfo($ch), 1)); curl_close($ch); if ($data) { // 保存文件 file_put_contents($dir.$file_name, $data); } } } // 压缩文件 // $dir 扫描目录 // $filename 压缩文件名 public function compress($dir, $filename = false){ if (!file_exists($dir)) { return false; } $file_lists = scandir($dir); // 扫描文件夹 $file_lists = array_diff($file_lists, ['.', '..']); //去除上级目录和当前目录 if (empty($file_lists)) { return false; } if (!$filename) { $filename = time().rand(111, 999).'.zip'; } else { $filename .= '.zip'; } $fullname = $dir.$filename; // 带路径的压缩文件名 if (!file_exists($fullname)) { $zip = new ZipArchive(); if ($zip->open($fullname, ZipArchive::CREATE)==TRUE) { foreach($file_lists as $val){ if(file_exists($dir.$val)){ $zip->addFile($dir.$val, $val); } } $zip->close(); } } return $filename; } // 递归删除文件和文件夹 // $path 要删除的文件路径 public function deleteDir($path) { //如果是目录则继续 if (is_dir($path)) { $file_lists = scandir($path);//扫描一个文件夹内的所有文件夹和文件并返回数组 foreach ($file_lists as $val) {//排除目录中的.和.. if ($val != "." && $val != "..") {//如果是目录则递归子目录,继续操作 if (is_dir($path . $val)) {//子目录中操作删除文件夹和文件 self::deleteDir($path . $val . '/');//目录清空后删除空文件夹 @rmdir($path . $val . '/'); } else {//如果是文件直接删除 unlink($path . $val); } } } @rmdir($path); } } }
以上是php下载远程文件的源码介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

如果您是一位经验丰富的 PHP 开发人员,您可能会感觉您已经在那里并且已经完成了。您已经开发了大量的应用程序,调试了数百万行代码,并调整了一堆脚本来实现操作

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

字符串是由字符组成的序列,包括字母、数字和符号。本教程将学习如何使用不同的方法在PHP中计算给定字符串中元音的数量。英语中的元音是a、e、i、o、u,它们可以是大写或小写。 什么是元音? 元音是代表特定语音的字母字符。英语中共有五个元音,包括大写和小写: a, e, i, o, u 示例 1 输入:字符串 = "Tutorialspoint" 输出:6 解释 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。总共有 6 个元

本教程演示了如何使用PHP有效地处理XML文档。 XML(可扩展的标记语言)是一种用于人类可读性和机器解析的多功能文本标记语言。它通常用于数据存储

静态绑定(static::)在PHP中实现晚期静态绑定(LSB),允许在静态上下文中引用调用类而非定义类。1)解析过程在运行时进行,2)在继承关系中向上查找调用类,3)可能带来性能开销。

PHP的魔法方法有哪些?PHP的魔法方法包括:1.\_\_construct,用于初始化对象;2.\_\_destruct,用于清理资源;3.\_\_call,处理不存在的方法调用;4.\_\_get,实现动态属性访问;5.\_\_set,实现动态属性设置。这些方法在特定情况下自动调用,提升代码的灵活性和效率。
