• 技术文章 >web前端 >js教程

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

    青灯夜游青灯夜游2021-03-04 10:36:16转载419
    本篇文章给大家介绍一下node.js使用multer中间件解决post文件上传问题的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

    相关推荐:《nodejs 教程

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

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

    难受…

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

    var form=new formidable.IncomingForm();

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

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


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

    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() ,它里面要指定一个参数——前端<input> 里的name名!如本例中还可以这样写:

    server.use(objMulter.single('f1'));

    前端代码如下 —— 文件提交,指定格式为multipart/form-data

    <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);

    更多编程相关知识,请访问:编程学习!!

    以上就是node.js使用multer中间件上传文件的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    上一篇:浅谈Angular中http请求模块的用法 下一篇:JavaScript专题之四:节流
    大前端线上培训班

    相关文章推荐

    • 详解nodejs中的queryString模块• 比较一下nodejs中间件Koa和Express• 深入浅析nodejs中的events模块• 卸载node的命令

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网