国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Nodejs實現文件上傳的示例代碼

2019-11-19 15:18:15
字體:
來源:轉載
供稿:網友

筆者用nodejs做項目時需要用到文件上傳的功能,在網上搜索了很多教程,找到了一個express的中間件,用于處理 multipart/form-data 類型的表單數據,可以很方便的將表單中的文件數據保存到服務器。

介紹

簡單的用法

定義存儲器

Multer作為express的一個中間件,我們可以很方便的自定義上傳的文件目錄以及保存的文件名。先看一個最簡單的用法, demo1地址

var express = require('express');var multer = require('multer');var app = express();var upload = multer({  storage: multer.diskStorage({    destination: function (req, file, cb){      cb(null, './uploads/');    },    filename: function (req, file, cb){      //file.originalname上傳文件的原始文件名      var changedName = (new Date().getTime())+'-'+file.originalname;      cb(null, changedName);    }  })});

我們先創建了一個upload對象,這個對象中destination函數用來定義上傳文件的存儲的文件夾;filename函數用來修改上傳文件存儲到服務器的文件名稱,這里我們我們加上一個時間戳簡單區分一下。這兩個函數都是通過回調函數來實現的。每次上傳的時候這兩個函數都會調用一次,如果是多個文件上傳,那個這兩個函數就調用多次,調用順序是先調用destination,然后調用filename。

在兩個函數中都會有一個 file 對象,表示當前上傳的文件對象,有以下幾個屬性:

  • fieldname:上傳的字段名
  • originalname:上傳的文件名
  • encoding:文件的編碼類型
  • mimetype:文件的MIME類型

定義路由回調

//單個文件上傳app.post('/upload/single',upload.single('singleFile'),(req,res)=>{  console.log(req.file);  res.json({    code: '0000',    type:'single',    originalname: req.file.originalname  })});//多個文件上傳app.post('/upload/multer',upload.array('multerFile'),(req,res)=>{  console.log(req.files);  let fileList = [];  req.files.map((elem)=>{    fileList.push({      originalname: elem.originalname    })  });  res.json({    code: '0000',    type:'multer',    fileList:fileList  });});

在express中定義路由的回調函數時,把定義好了的upload對象作為中間件添加進去。如果是單個文件就用 single 方法,如果是多個文件就用 array 方法,這兩個方法都需要傳一個頁面上定義好的字段名。

在路由的回調函數中,request對象已經有了file屬性(單個文件上傳)或files屬性(多個文件上傳),files屬性是一個數組,數組的每一個對象都有以下屬性:

  • fieldname:上傳的字段名
  • originalname:上傳的文件名
  • encoding:文件的編碼類型
  • mimetype:文件的MIME類型
  • destination:存儲的目錄(和destination回調函數中的目錄名一致)
  • filename:保存的文件名(和filename回調函數中的文件名一致)
  • path:保存的相對路徑
  • size:文件的大小(單位:字節byte)

我們可以發現在路由的回調函數中的file對象比diskStorage中的file對象多了幾個屬性,這是因為在diskStorage中文件還沒有保存,只能知道文件的大致屬性;而路由的回調函數文件已經在服務器上保存好了,文件的保存路徑以及文件的大小都是已知的。

過濾文件上傳

在文件上傳時,有時候會上傳一些我們不需要的文件類型,我們需要把一些不需要的文件給過濾掉。demo2地址

文件類型過濾

var upload = multer({  //...其他代碼  fileFilter: function(req, file, cb){    if(file.mimetype == 'image/png'){      cb(null, true)    } else {      cb(null, false)    }  }});

在定義存儲器的時候,新增一個fileFilter函數,用來過濾掉我們不需要的文件,在回調函數中我們傳入true/false來代表是否要保存;如果傳了false,那么destination函數和filename函數也不會調用了。

文件大小和數量過濾

var upload = multer({  //...其他代碼  limits:{    //限制文件大小10kb    fileSize: 10*1000,    //限制文件數量    files: 5  }});

在定義存儲器的時候,新增一個limits對象,用來控制上傳的一些信息,它有以下一些屬性:

  • fieldNameSize:field 名字最大長度,默認值:100 bytes
  • fieldSize:field 值的最大長度,默認值:1MB
  • fields:非文件 field 的最大數量
  • fileSize:在multipart表單中, 文件最大長度 (字節單位)
  • files:在multipart表單中, 文件最大數量
  • parts:在multipart表單中, part傳輸的最大數量(fields + files)

在這邊我們把fileSize的值設置得小一點,設為10kb方便測試看效果,但是如果這個時候會發現有報錯。因為上傳的文件大小很容易就會超過10KB,導致有報錯出現,我們就需要在路由回調里對錯誤的情況進行捕獲。

//單個文件上傳let singleUpload = upload.single('singleFile');app.post('/upload/single',(req,res)=>{  singleUpload(req,res,(err)=>{    if(!!err){      console.log(err.message)      res.json({        code: '2000',        type:'single',        originalname: '',        msg: err.message      })      return;    }    if(!!req.file){      res.json({        code: '0000',        type:'single',        originalname: req.file.originalname,        msg: ''      })    } else {      res.json({        code: '1000',        type:'single',        originalname: '',        msg: ''      })    }  });});//多個文件上傳let multerUpload = upload.array('multerFile');app.post('/upload/multer', (req,res)=>{  multerUpload(req,res,(err)=>{    if(!!err){      res.json({        code: '2000',        type:'multer',        fileList:[],        msg: err.message      });    }    let fileList = [];    req.files.map((elem)=>{      fileList.push({        originalname: elem.originalname      })    });    res.json({      code: '0000',      type:'multer',      fileList:fileList,      msg:''    });  });});

所有的demo代碼都在這個 倉庫里

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 兰坪| 定安县| 商城县| 余干县| 安阳市| 博罗县| 大洼县| 营山县| 宕昌县| 河津市| 南靖县| 建始县| 湟中县| 嵩明县| 丰顺县| 宁明县| 汉川市| 绥芬河市| 安图县| 壤塘县| 随州市| 延安市| 永吉县| 获嘉县| 石棉县| 文安县| 济南市| 文水县| 静安区| 深泽县| 新平| 余庆县| 双牌县| 太谷县| 丹棱县| 商丘市| 濉溪县| 石河子市| 会理县| 嘉定区| 普兰店市|