Nodejs实现文件上传的示例代码(2)

  • 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:''
        });
      });
    });
    
    
          

    内容版权声明:除非注明,否则皆为本站原创文章。

    转载注明出处:http://www.heiqu.com/6120.html