广告
返回顶部
首页 > 资讯 > 精选 >node.js使用multer中间件上传文件的方法
  • 741
分享到

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

2023-06-06 18:06:24 741人浏览 八月长安
摘要

这篇文章主要介绍了node.js使用multer中间件上传文件的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。body-parser中间件,其实“极不完美” —— 它只能

这篇文章主要介绍了node.js使用multer中间件上传文件的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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

  • 数据提交(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中间件上传文件的方法”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: node.js使用multer中间件上传文件的方法

本文链接: https://www.lsjlt.com/news/248127.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • node.js使用multer中间件上传文件的方法
    这篇文章主要介绍了node.js使用multer中间件上传文件的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。body-parser中间件,其实“极不完美” —— 它只能...
    99+
    2023-06-06
  • express文件上传中间件Multer详解
    前言 Express默认并不处理HTTP请求体中的数据,对于普通请求体(JSON、二进制、字符串)数据,可以使用body-parser中间件。而文件上传(multipart/form-data请求),可以基...
    99+
    2022-06-04
    详解 文件上传 中间件
  • 怎么用node+multer中间件实现单文件、多文件上传
    本篇内容介绍了“怎么用node+multer中间件实现单文件、多文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能...
    99+
    2022-10-19
  • 在Node.js中使用HTTP上传文件的方法
    开发环境 我们将使用 Visual Studio Express 2013 for Web 作为开发环境, 不过它还不能被用来做 Node.js 开发。为此我们需要安装 Node.js Tools for ...
    99+
    2022-06-04
    上传文件 方法 Node
  • node.js使用express-fileupload中间件实现文件上传
    目录初始化项目 编写服务器 初始化客户端 编写组件 FileUpload Message.js Progress.js 测试 本文使用express作为服务端,使用express-f...
    99+
    2022-11-12
  • Nodejs+express中间件实现文件上传的方法
    小编给大家分享一下Nodejs+express中间件实现文件上传的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!用nodejs做项目时需要用到文件上传的功能,...
    99+
    2023-06-14
  • 关于node使用multer进行文件的上传与下载
    首先了解下浏览器的自动下载: 使用Express静态资源中间件的默认行为是在浏览器中展示静态文件,而不是自动下载。 如果需要访问静态资源时自动下载,可以在HTTP响应中设置Conte...
    99+
    2023-05-16
    node multer multer上传下载
  • node.js如何使用express-fileupload中间件实现文件上传
    本篇内容介绍了“node.js如何使用express-fileupload中间件实现文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目...
    99+
    2023-06-20
  • node.js怎么使用express-fileupload中间件实现文件上传
    本篇内容介绍了“node.js怎么使用express-fileupload中间件实现文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本...
    99+
    2023-06-17
  • Nodejs中怎么利用express和multer实现文件上传
    这期内容当中小编将会给大家带来有关Nodejs中怎么利用express和multer实现文件上传,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。非常简单,一行命令。npm&...
    99+
    2022-10-19
  • PHP上传文件的使用方法
    本篇内容介绍了“PHP上传文件的使用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!PHP 4.0.3之后PHP又出了一个新函数move_...
    99+
    2023-06-17
  • Asp.Net上传文件并配置可上传大文件的方法
    ASP.NET 包含两个控件可以使用户向网页服务器上传文件。一旦服务器接受了上传的文件数据,那么应用程序就可以进行保存,进行检查或者忽略它。 HtmlInputFile -...
    99+
    2022-11-13
  • 关于文件上传MultipartBody的使用方法
    目录文件上传MultipartBody的使用下面给出核心的代码,然后分析一下MultipartBody取出key,value数据,打印参数文件上传MultipartBody的使用 最...
    99+
    2022-11-13
  • ASP中文件上传组件ASPUpload介绍和使用方法
    ASPUpload是一个用于在ASP网页中实现文件上传的组件。它提供了简单易用的接口和丰富的功能,方便开发者在网页中实现文件上传功能...
    99+
    2023-08-22
    ASP
  • 使用sftp命令上传文件夹方法
    # 前言sftp上传单个文件使用put,多个文件可使用mput,但是要上传整个文件夹,则比较复杂,需要使用多个命令组合,包括find、awk等。# sftp上传文件夹```#!/bin/bash sss=`find /ngs/ec...
    99+
    2023-06-06
  • SpringMVC上传文件的两种方法
    在该示例中,阐述了SpringMVC如何上传文件。1、上传页面upload.jsp<body> <form action="/TestSpringMVC3/data/uploadfile" enctype="multi...
    99+
    2023-05-30
    springmvc 上传 sprin
  • Servlet3.0实现文件上传的方法
    Servlet 实现文件上传所谓文件上传就是将本地的文件发送到服务器中保存。例如我们向百度网盘中上传本地的资源或者我们将写好的博客上传到服务器等等就是典型的文件上传。Servlet 3.0上次完成文件下载功能使用的是 Servlet 2.5...
    99+
    2023-05-31
    servlet 文件上传 实现文件
  • django1.8使用表单上传文件的实现方法
    Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 在d...
    99+
    2022-06-04
    表单 上传文件 方法
  • Node.js连接mongo数据库上传文件的方法步骤
    目录效果初始化model 下创建index.js用于连接数据库时的信息修改app.js文件里的信息router下修改user.js文件创建上传文件保存文件夹在public下新建一个i...
    99+
    2022-11-13
  • 如何使用大文件上传:秒传、断点续传、分片上传方法
    本篇内容介绍了“如何使用大文件上传:秒传、断点续传、分片上传方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!秒传1、什么是秒传通俗的说,你...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作