• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > Nodejs+express中间件实现文件上传

Nodejs+express中间件实现文件上传

作者:站长图库 字体:[增加 减小] 来源:互联网

站长图库向大家介绍了Nodejs,express中间件,文件上传等相关知识,希望对您有所帮助

本篇文章给大家详细介绍Nodejs文件上传的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。


Nodejs+express中间件实现文件上传


笔者用nodejs做项目时需要用到文件上传的功能,在网上搜索了很多教程,找到了一个express的中间件,用于处理multipart/form-data类型的表单数据,可以很方便的将表单中的文件数据保存到服务器。

介绍

multer是一个node.js文件上传中间件,它是在 busboy的基础上开发的,上传的表单数据必须是multipart/form-data类型,不然会报错。

简单的用法

定义存储器

Multer作为express的一个中间件,我们可以很方便的自定义上传的文件目录以及保存的文件名。先看一个最简单的用法,demo1地址:

var express = require('express');var multer = require('multer');var app = express(); var upload = multer({    storage: multer.diskStorage({        destination: function (req, file, cb) {            cb(null, './uploads/');        },        filename: function (req, file, cb) {            //file.originalname上传文件的原始文件名            var changedName = (new Date().getTime())+'-'+file.originalname;            cb(null, changedName);        }    })});

我们先创建了一个upload对象,这个对象中destination函数用来定义上传文件的存储的文件夹;filename函数用来修改上传文件存储到服务器的文件名称,这里我们我们加上一个时间戳简单区分一下。这两个函数都是通过回调函数来实现的。每次上传的时候这两个函数都会调用一次,如果是多个文件上传,那个这两个函数就调用多次,调用顺序是先调用destination,然后调用filename。


在两个函数中都会有一个file对象,表示当前上传的文件对象,有以下几个属性:

fieldname:上传的字段名

originalname:上传的文件名

encoding:文件的编码类型

mimetype:文件的MIME类型

附:一些常用的MIME类型


定义路由回调

//单个文件上传app.post('/upload/single',upload.single('singleFile'),(req,res)=>{    console.log(req.file);    res.json({        code: '0000',        type:'single',        originalname: req.file.originalname    })}); //多个文件上传app.post('/upload/multer',upload.array('multerFile'),(req,res)=>{    console.log(req.files);    let fileList = [];    req.files.map((elem)=>{        fileList.push({            originalname: elem.originalname        })    });    res.json({        code: '0000',        type:'multer',        fileList:fileList    });});


在express中定义路由的回调函数时,把定义好了的upload对象作为中间件添加进去。如果是单个文件就用single方法,如果是多个文件就用array方法,这两个方法都需要传一个页面上定义好的字段名。

在路由的回调函数中,request对象已经有了file属性(单个文件上传)或files属性(多个文件上传),files属性是一个数组,数组的每一个对象都有以下属性:

fieldname:上传的字段名

originalname:上传的文件名

encoding:文件的编码类型

mimetype:文件的MIME类型

destination:存储的目录(和destination回调函数中的目录名一致)

filename:保存的文件名(和filename回调函数中的文件名一致)

path:保存的相对路径

size:文件的大小(单位:字节byte)

我们可以发现在路由的回调函数中的file对象比diskStorage中的file对象多了几个属性,这是因为在diskStorage中文件还没有保存,只能知道文件的大致属性;而路由的回调函数文件已经在服务器上保存好了,文件的保存路径以及文件的大小都是已知的。


混合上传

有时候我们可能需要用字段名来对上传的文件进行一下划分,比如说上传多个图片的时候可能有身份证还有头像。虽然可以分开放到两个接口中,但是会产生其他一系列的麻烦事。multer支持对图片进行字段名的划分。demo3地址


//多字段名上传let multipleFields = upload.fields([    {name:'avatar'},    {name:'gallery', maxCount:3},]);app.post('/upload/fields', (req,res)=>{    multipleFields(req,res,(err) => {        console.log(req.files);        if(!!err){            console.log(err.message);            res.json({                code: '2000',                type: 'field',                msg:err.message            })            return;        }        var fileList = [];        for(let item in req.files){            var fieldItem = req.files[item];            fieldItem.map((elem) => {                fileList.push({                    fieldname: elem.fieldname,                    originalname: elem.originalname                })            });        }        res.json({            code: '0000',            type: 'field',            fileList: fileList,            msg:''        })    });});

在这边也有req.files属性,但是这个属性并

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何升级或修改nodejs的版本
  • Nodejs路由可通过什么模块实现的
  • 实战分享:利用nodejs​爬取并下载一万多张图片
  • Nodejs中如何定义全局变量
  • 浅谈Nodejs中的callback回调
  • nodeJS把json数据转成excel(xlsx文件)输出
  • 浅谈nodejs利用node-xlsx模块读取excel数据的方法
  • 聊聊Nodejs获取参数的四种方法
  • 浅析利用nodejs怎么给图片添加半透明水印(方法详解)
  • Nodejs+express中间件实现文件上传

相关文章

  • 被遗忘的WordPress模板标签有哪些?
  • 关于ThinkPHP的join关联查询不使用默认的表前缀
  • CSS如何修改placeholder的颜色
  • AI和PS快速制作漂亮复古海报
  • Photoshop制作地裂火焰效果艺术字教程
  • wordpress打开速度慢最佳解决方案
  • Photoshop制作颓废的彩色立体字
  • PHP中fopen()函数的使用(附代码示例)
  • WordPress获取指定标签下的文章总数
  • 织梦熊掌号api自动提交代码

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • 帝国CMS安装时You have an error in your SQL syntax报错
    • 详解thinkphp下部分内容的ajax无刷新分页
    • 如何解决mysql报错“#1067 invalid default value”
    • 分享推荐一款好用的TP富文本编辑器-CKEditor
    • 第三方下载苹果CMSV10系统的请注意后门WebShell
    • 网站文字循环变色代码
    • PhotoShop制作滚动渐隐文字GIF动画教程
    • SQL语句中的with as该怎么用
    • PS制作常用水晶按钮
    • 一文浅析Angular中的响应式表单

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有