node.js使用multer中间件上传文件


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章给大家介绍一下node.js使用multer中间件解决post文件上传问题的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

相关推荐:《nodejs 教程》

body-parser中间件,其实“极不完美” ―― 它只能处理“单纯的数据”。
众所周知,post常用于两件事:

  • 数据提交(post表单提交)

  • 文件上传

但“大名鼎鼎”的body-parser只能做到第一点。

难受…

以前写过的图片文件上传文章中用到了formidable模块,其核心在于:

1

var form=new formidable.IncomingForm();

其后的form.uploadDirfield/end的监听 … 都是基于此。

好了这里我们要说的是缺点:和body-parser一样,formidable插件只能用来处理图片格式,也是一大遗憾了。


于是,笔者找到了 multer中间件 ,希望它能“拯救者支离破碎的山河” (呵呵)

multer中间件的应用之一:文件上传

1

(c)npm install express multer

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

const express = require('express');

const bodyparser = require('body-parser');//解析post数据

const multer = require('multer'); //解析Post文件

const fs = require('fs');

const pathlib = require('path'); //解析文件路径

  

var server = express();

  

var objMulter = multer({dest:'./www/upload'}); //用户上传文件存入dest目录下

server.use(objMulter.any()); //处理任何用户上传的文件

  

//处理post文件数据

server.post('/',function(req,res){

    console.log(req.files[0].originalname); //req.files post文件 originalname为文件名

  

    //获取原始拓展名+后缀名

    var newName = req.files[0].path+pathlib.parse(req.files[0].originalname).ext;

  

    //重命名

    fs.rename(req.files[0].path,newName,function(err){

        if(err){

            res.send('上传失败');

        }else{

            res.send('上传成功');

        }

    });

});

server.listen(8081);

这里,用req.files顶替了req.body:因为body中只能存放(文字)数锯――这里如果用body-parser的话,看到的只是控制台上显示的文件名。

代码中objMulter.any() 作用是“ 获取所有数据 ”;
any() 相对的还有一个single() ,它里面要指定一个参数――前端<input> 里的name名!如本例中还可以这样写:

阅读剩余部分

相关阅读 >>

node.js如何使用文件系统模块?常用fs模块方法介绍

node.js学习之静态资源服务器

javascript在nodejs环境下执行机制和事件循环

win怎样升级react native 和node.js

node.js+koa搭建一个简单后台管理系统

cors跨域资源共享详细介绍(附代码)

浅谈node.js中require()的工作原理

nodejs http请求相关的总结介绍

谈谈node.js中的文件写入

深入了解node.js中的express框架

更多相关阅读请进入《node.js》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...