重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍了node.js使用multer中间件上传文件的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
创新互联是一家成都网站制作、成都网站建设,提供网页设计,网站设计,网站制作,建网站,定制网站,网站开发公司,2013年开创至今是互联行业建设者,服务者。以提升客户品牌价值为核心业务,全程参与项目的网站策划设计制作,前端开发,后台程序制作以及后期项目运营并提出专业建议和思路。
body-parser中间件,其实“极不完美” —— 它只能处理“单纯的数据”。
众所周知,post常用于两件事:
数据提交(post表单提交)
文件上传
但“大名鼎鼎”的body-parser只能做到第一点。
难受…
以前写过的图片文件上传文章中用到了formidable模块,其核心在于:
var form=new formidable.IncomingForm();
其后的form.uploadDir
、field/end的监听 … 都是基于此。
好了这里我们要说的是缺点:和body-parser一样,formidable插件只能用来处理图片格式,也是一大遗憾了。
于是,笔者找到了 multer中间件,希望它能“拯救者支离破碎的山河” (呵呵)
(c)npm install express multer
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()
,它里面要指定一个参数——前端 里的name名!如本例中还可以这样写:
server.use(objMulter.single('f1'));
前端代码如下 —— 文件提交,指定格式为multipart/form-data
:
其实就是用了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);
感谢你能够认真阅读完这篇文章,希望小编分享的“node.js使用multer中间件上传文件的方法”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!