摘要:文章轉自更多文章如果您需要您的用戶支持多文件下載的話,最好的辦法是創建一個壓縮包并提供下載。你看,你不需要任何的擴展包來實現這個壓縮方式。
文章轉自: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...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/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文件,輕則產生本地拒絕服務漏洞...
閱讀 2566·2021-09-02 15:40
閱讀 1572·2019-08-30 15:54
閱讀 1086·2019-08-30 12:48
閱讀 3405·2019-08-29 17:23
閱讀 1052·2019-08-28 18:04
閱讀 3670·2019-08-26 13:54
閱讀 611·2019-08-26 11:40
閱讀 2400·2019-08-26 10:15