摘要:文章转自更多文章如果您需要您的用户支持多文件下载的话,最好的办法是创建一个压缩包并提供下载。你看,你不需要任何的扩展包来实现这个压缩方式。
文章转自:https://learnku.com/laravel/t...
更多文章:https://learnku.com/laravel/c...
如果您需要您的用户支持多文件下载的话,最好的办法是创建一个压缩包并提供下载。看下在 Laravel 中的实现。
事实上,这不是关于 Laravel 的,而是和 PHP 的关联更多,我们准备使用从 PHP 5.2 以来就存在的 ZipArchive 类 ,如果要使用,需要确保php.ini 中的 ext-zip 扩展开启。
任务 1: 存储用户的发票文件到 storage/invoices/aaa001.pdf下面是代码展示:
$zip_file = "invoices.zip"; // 要下载的压缩包的名称 // 初始化 PHP 类 $zip = new ipArchive(); $zip->open($zip_file, ipArchive::CREATE | ipArchive::OVERWRITE); $invoice_file = "invoices/aaa001.pdf"; // 添加文件:第二个参数是待压缩文件在压缩包中的路径 // 所以,它将在 ZIP 中创建另一个名为 "storage/" 的路径,并把文件放入目录。 $zip->addFile(storage_path($invoice_file), $invoice_file); $zip->close(); // 我们将会在文件下载后立刻把文件返回原样 return response()->download($zip_file);
例子很简单,对吗?
*
任务 2: 压缩 全部 文件到 storage/invoices 目录中Laravel 方面不需要有任何改变,我们只需要添加一些简单的 PHP 代码来迭代这些文件。
$zip_file = "invoices.zip"; $zip = new ipArchive(); $zip->open($zip_file, ipArchive::CREATE | ipArchive::OVERWRITE); $path = storage_path("invoices"); $files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)); foreach ($files as $name => $file) { // 我们要跳过所有子目录 if (!$file->isDir()) { $filePath = $file->getRealPath(); // 用 substr/strlen 获取文件扩展名 $relativePath = "invoices/" . substr($filePath, strlen($path) + 1); $zip->addFile($filePath, $relativePath); } } $zip->close(); return response()->download($zip_file);
到这里基本就算完成了。你看,你不需要任何 Laravel 的扩展包来实现这个压缩方式。
文章转自:https://learnku.com/laravel/t...
更多文章:https://learnku.com/laravel/c...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/31159.html
摘要:第二步添加在项目中创建文件。项目是官方的开源项目,负责实现对容器集群的快速编排。在这里我们会用到四个容器分别将放在四个不同的容器中,通过将四个应用容器关联到一起组成项目。服务服务的容器将执行我们项目中的代码。 showImg(https://segmentfault.com/img/bVbpfM5?w=695&h=270);在这篇文章中我们将通过Docker在个人本地电脑上构建一个快速...
摘要:可以将称为追踪服务器或调度服务器。实际保存文件分为多个组,每个组之间保存的文件是不同的。虚拟磁盘路径配置的虚拟路径,与磁盘选项对应。数据两级目录服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据文件。1.什么是FastDFS FastDFS是用 c 语言编写的一款开源的分布式文件系统。FastDFS 为互联网量身定制, 充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等...
摘要:阿里聚安全的应用漏洞扫描服务,可以检测出应用的文件目录遍历风险。阿里聚安全对开发者建议对重要的压缩包文件进行数字签名校验,校验通过才进行解压。 1、ZIP文件目录遍历简介 因为ZIP压缩包文件中允许存在../的字符串,攻击者可以利用多个../在解压时改变ZIP包中某个文件的存放位置,覆盖掉应用原有的文件。如果被覆盖掉的文件是动态链接so、dex或者odex文件,轻则产生本地拒绝服务漏洞...
阅读 2563·2021-09-02 15:40
阅读 1568·2019-08-30 15:54
阅读 1082·2019-08-30 12:48
阅读 3400·2019-08-29 17:23
阅读 1047·2019-08-28 18:04
阅读 3666·2019-08-26 13:54
阅读 607·2019-08-26 11:40
阅读 2394·2019-08-26 10:15