在Cloud APP上傳檔案與下載時,因為顧及到主機Scale out時候檔案存放位置會影響到Scale out出來的主機如何存取新上傳的檔案,在雲端,透過Cloud Storage是一個不錯的解決方案... Node.js跟許多語言在file upload的處理方式有點不同,以Express為例,我們可以透過app.use()來導入其他的模組作為控管檔案上傳的部分,而我最常使用的是 multr 這個模組... 這次透過一些改寫,希望基於multr讓上傳、下載的動作直接結合Cloud Storage來作為存取的位置。 下面這是整個上傳與下載的示意圖: 上圖分成兩個部分: 上傳的部分,無論如何直接將一份副本複製到Cloud Storage 下載的部分,主要依循幾個策略: 如果本地端有檔案,則直接使用本地端檔案回覆 如果本地端無檔案,系統直接到Cloud Storage拉檔案 承上,如果使用者允許cache,可以在拉完Cloud Storage檔案後,在存放一個副本在本地端,之後就可以支援從本地端存取功能 上面所述,因為效能關係,可能會開啟cache的功能,如果上傳的檔案名稱不是唯一,則可能重複上傳後再本地端會有舊資料問題,為了避免這個問題,在設定檔中可以指定上傳時候不維持原檔名,這樣每次上傳會以重新編碼檔名,讓每一個物件名稱不會重複。 安裝 npm install express-gcs-uploader --save 設定 Step1: 與Cloud Storage認證部分設定 var gcsuplder = require('express-gcs-uploader'); gcsuplder.auth({ rootdir: __dirname, //設定專案目錄位置,在這邊是為了對應uploads目錄用 upload_url: '/uploads', //上傳檔案的資料夾 download_url: '/download', //檔案下載的路由 cdn_url: 'http://your.bucket.com.tw', //option: 如果GCS設定為public或是website buke...