您好,登錄后才能下訂單哦!
這篇文章主要介紹“node中multer的概念是什么”,在日常操作中,相信很多人在node中multer的概念是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”node中multer的概念是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在node中,multer是一個用于處理“multipart/form-data”類型數據格式的中間件,主要用于上傳文件;該中間件在解析完請求體后,會向Request對象中添加一個body對象和一個file或files對象。
本文操作環境:Windows10系統、nodejs 12.19.0版、Dell G3電腦。
Multer 是一個 node.js 中間件,用于處理 multipart/form-data 類型的表單數據,它主要用于上傳文件。它是寫在 busboy 之上非常高效。
注意: Multer 不會處理任何非 multipart/form-data 類型的表單數據
Multer在解析完請求體后,會向Request對象中添加一個body對象和一個file或files對象(上傳多個文件時使用files對象 )。
其中,body對象中包含所提交表單中的文本字段(如果有),而file(或files)對象中包含通過表單上傳的文件。
Tips:multipart/form-data是用來指定傳輸數據的特殊類型的,主要就是我們上傳的非文本的內容,比如圖片或者mp3等等
const express = require('express') const multer = require('multer') const app = express() const storage = multer.diskStorage({ //保存路徑 destination: function (req, file, cb) { cb(null, '/tmp/my-uploads') //注意這里的文件路徑,不是相對路徑,直接填寫從項目根路徑開始寫就行了 }, //保存在 destination 中的文件名 filename: function (req, file, cb) { cb(null, file.fieldname + '-' + Date.now()) } }) const upload = multer({ storage: storage }) app.post('/profile', upload.single('avatar'), function (req, res, next) { // req.file 是 `avatar` 文件的信息 // req.body 將具有文本域數據,如果存在的話 }) app.post('/photos/upload', upload.array('photos', 12), function (req, res, next) { // req.files 是 `photos` 文件數組的信息 // req.body 將具有文本域數據,如果存在的話 }) const cpUpload = upload.fields([{ name: 'avatar', maxCount: 1 }, { name: 'gallery', maxCount: 8 }]) app.post('/cool-profile', cpUpload, function (req, res, next) { // req.files 是一個對象 (String -> Array) 鍵是文件名,值是文件數組 // 例如: // req.files['avatar'][0] -> File // req.files['gallery'] -> Array // req.body 將具有文本域數據,如果存在的話 })
multer(options)
Multer 接受一個 options 對象,其中最基本的是 dest 屬性,這將告訴 Multer 將上傳文件保存在哪。如果你省略 options 對象,這些文件將保存在內存中,永遠不會寫入磁盤。
通常,一般的網頁應用,只需要設置 dest 屬性,像這樣:
const upload = multer({ dest: 'uploads/' })
如果你想在上傳時進行更多的控制,你可以使用 storage 選項替代 dest。Multer 具有 DiskStorage 和 MemoryStorage 兩個存儲引擎; 另外還可以從第三方獲得更多可用的引擎。
到此,關于“node中multer的概念是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。