我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章主要介绍了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中间件上传文件的方法”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

下载Word文档

猜你喜欢

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

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

express文件上传中间件Multer详解

前言 Express默认并不处理HTTP请求体中的数据,对于普通请求体(JSON、二进制、字符串)数据,可以使用body-parser中间件。而文件上传(multipart/form-data请求),可以基于请求流处理,也可以使用formi
2022-06-04

在Node.js中使用HTTP上传文件的方法

开发环境 我们将使用 Visual Studio Express 2013 for Web 作为开发环境, 不过它还不能被用来做 Node.js 开发。为此我们需要安装 Node.js Tools for Visual Studio。 装
2022-06-04

node.js如何使用express-fileupload中间件实现文件上传

本篇内容介绍了“node.js如何使用express-fileupload中间件实现文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目
2023-06-20

node.js怎么使用express-fileupload中间件实现文件上传

本篇内容介绍了“node.js怎么使用express-fileupload中间件实现文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本
2023-06-17

关于node使用multer进行文件的上传与下载

这篇文章主要介绍了关于node使用multer进行文件的上传与下载,Multer是一个Node.js中间件,用于处理表单数据中的multipart/form-data类型,需要的朋友可以参考下
2023-05-16

PHP上传文件的使用方法

本篇内容介绍了“PHP上传文件的使用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!PHP 4.0.3之后PHP又出了一个新函数move_
2023-06-17

Nodejs+express中间件实现文件上传的方法

小编给大家分享一下Nodejs+express中间件实现文件上传的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!用nodejs做项目时需要用到文件上传的功能,
2023-06-14

ASP中文件上传组件ASPUpload介绍和使用方法

ASPUpload是一个用于在ASP网页中实现文件上传的组件。它提供了简单易用的接口和丰富的功能,方便开发者在网页中实现文件上传功能。使用方法如下:1. 首先,需要将ASPUpload组件添加到项目中。可以从官方网站(http://www.
2023-08-22

使用sftp命令上传文件夹方法

# 前言sftp上传单个文件使用put,多个文件可使用mput,但是要上传整个文件夹,则比较复杂,需要使用多个命令组合,包括find、awk等。# sftp上传文件夹```#!/bin/bash sss=`find /ngs/ecv1/Ap
2023-06-06

node.js怎么使用express-fileupload实现文件上传

这篇文章主要讲解了“node.js怎么使用express-fileupload实现文件上传”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“node.js怎么使用express-fileuplo
2023-07-04

django1.8使用表单上传文件的实现方法

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。Django是一个开放源代码的Web应用框架,由Python写成。 在django中我们可以采用Form类来处
2022-06-04

NodeJS使用七牛云存储上传文件的方法

1-准备工作 确认安装node和npm 安装 qiniu,formidable,express模块npm install --save qiniu formidable[x] 导入模块let qiniu = require('qiniu')
2022-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录