本篇文章给大家介绍一下node.js使用multer中间件解决post文件上传问题的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
相关推荐:《nodejs 教程》
body-parser中间件,其实“极不完美” —— 它只能处理“单纯的数据”。
众所周知,post常用于两件事:
但“大名鼎鼎”的body-parser只能做到第一点。
难受…
以前写过的图片文件上传文章中用到了formidable模块,其核心在于:
1 | var form= new formidable.IncomingForm();
|
登录后复制
其后的form.uploadDir
、field/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(& #39;express');
const bodyparser = require(& #39;body-parser');//解析post数据
const multer = require(& #39;multer'); //解析Post文件
const fs = require(& #39;fs');
const pathlib = require(& #39;path'); //解析文件路径
var server = express();
var objMulter = multer({dest:& #39;./www/upload'}); //用户上传文件存入dest目录下
server.use(objMulter.any());
server.post(& #39;/',function(req,res){
console.log(req.files[0].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(& #39;上传失败');
} else {
res.send(& #39;上传成功');
}
});
});
server.listen(8081);
|
登录后复制
这里,用req.files顶替了req.body:因为body中只能存放(文字)数锯——这里如果用body-parser的话,看到的只是控制台上显示的文件名。
代码中objMulter.any()
作用是“ 获取所有数据 ”;
与any()
相对的还有一个single()
,它里面要指定一个参数——前端<input>
里的name名!如本例中还可以这样写:
1 | server.use(objMulter.single(& #39;f1'));
|
登录后复制
前端代码如下 —— 文件提交,指定格式为multipart/form-data
:
1 2 3 4 | <form action= "http://localhost:8081/" method= "post" enctype= "multipart/form-data" >
文件:<input type= "file" name= "f1" /><br />
<input type= "submit" value= "上传" />
</form>
|
登录后复制
其实就是用了fs模块中的rename(原路径,新路径,callback)方法,通过将文件强制更改存放路径来达到“上传文件”的目的。
今日份扩展:
node中常用path模块中的resolve方法来“指定文件”(注意第16/17行):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | var http = require(& #39;http');
var fs = require(& #39;fs');
var path = require(& #39;path');
var server = http.createServer( function (req, res) {
var method = req.method;
if (method === & #39;POST') { // 暂只关注 post 请求
var dataStr = & #39;';
req.on(& #39;data', function (chunk) {
var chunkStr = chunk.toString()
dataStr += chunkStr
});
req.on(& #39;end', function () {
var fileName = path.resolve(__dirname, & #39;post.txt');
fs.writeFile(fileName, dataStr)
res.end(& #39;OK');
});
}
});
server.listen(8081);
|
登录后复制
更多编程相关知识,请访问:编程学习!!
以上是node.js使用multer中间件上传文件的详细内容。更多信息请关注PHP中文网其他相关文章!