body-parser中间件,其实“极不完美” —— 它只能处理“单纯的数据”。
众所周知,post常用于两件事:
- 数据提交(post表单提交)
- 文件上传
但“大名鼎鼎”的body-parser只能做到第一点。
难受…
以前写过“ 图片文件上传 ”的文章,里面用了formidable模块,其核心在于:
var form=new formidable.IncomingForm();
其后的form.uploadDir
、field/end的监听 … 都是基于此。
好了这里我们要说的是缺点:和body-parser一样,formidable只能处理图片格式,也是一大遗憾了。
于是,笔者找到了 multer中间件 ,希望它能“拯救者支离破碎的山河” (呵呵)
multer中间件的应用之一:文件上传
(c)npm install express multer
const express=require('express'); //用中间件一定要用此模块
const multer=require('multer');
const fs=require('fs');
//先确立multer对象,指定保存文件夹
var objMulter=multer({dest:'./www/upload/'});
var server=express();
server.use(objMulter.any());
server.post('/',function(req,res){
//加后缀(ext),重命名
var newName=req.files[0].path + pathLib.parse(req.files[0].originalname).ext;
//保存(rename方法——修改文件名称,更改文件存放路径)
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名!如本例中还可以这样写:
server.use(objMulter.single('f1'));
前端代码如下:
<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行):
var http = require('http');
var fs = require('fs');
var path = require('path');
var server = http.createServer(function (req, res) {
var method = req.method; // 获取请求方法
if (method === 'POST') { // 暂只关注 post 请求
var dataStr = '';
req.on('data', function (chunk) {
// 接收到数据,先存储起来
var chunkStr = chunk.toString()
dataStr += chunkStr
});
req.on('end', function () {
// 接收数据完成,将数据写入文件
var fileName = path.resolve(__dirname, 'post.txt');
fs.writeFile(fileName, dataStr)
res.end('OK');
});
}
});
server.listen(8081);