multer用于处理文件上传的nodejs中间件,主要跟express框架搭配使用,只支持表单MIME编码为multipart/form-data类型的数据请求.

如果要处理其他编码的表单数据可以通过busboy或者formidable。

multer模块的安装: npm install multer

构造multer对象: multer(opt)

opt是个key-value对象,包含属性dest/storage,fileFilter,limits.分表表示文件的存储位置/方式,文件过滤,文件大小限制.

例如:

//通过设置dest属性,表示上传文件的存储位置
let objmulter = multer({ dest: path.join(__dirname,'uploads')});

如果想对上传文件做更多的选项设置,比如文件名,存储类型等可以通过指定storagelet storage = multer.diskStorage({

//文件存储路径
destination: (req , file , cb )=>{
cb(null , path.join(__dirname , 'uploads'));
},
//修改上传文件的名字
//file 是个文件对象 ,fieldname对应在客户端的name属性
//存储的文件需要自己加上文件的后缀,multer并不会自动添加
//这里直接忽略文件的后缀.
filename: (req , file , cb ) => {
cb( null, file.fieldname +'-' + Date.now());
}
}); let objMulter = multer({storage : storage });

如果初始化multer时候没有指定dest或者storage,上传的文件将保存在内存中,永远不会写入到磁盘中,在storage中如果没有指定destination值,那么上传的文件将存储在系统默认的临时文件夹.

multer关联的文件信息:
filedname : 在form表单中指定的name属性值
orginalname : 原始文件名
encoding : 文件编码方式
mimetype : 多媒体类型
size : 文件大小,单位b
destination : 文件上传后存储在服务端的路径
filename : 文件在服务端的命名
path : 文件在服务端的完整路径
buffer : 文件二进制数据 ps:其中destination,filename和path只有在指定storage属性时候有效.而buffer只有文件在内存中存储时候有效.

multer同时提供了single/array/fields/any方法用于对接受文件数的控制.

1) single(fieldname) 接收单个文件,通过req.file访问该文件
2) array(fieldnaem,[maxcount]) 接收多个文件,通过req.files数组方法文件.maxcount指定接收文件最大数.
3) fields(fields) 接受指定fieldname的文件,fieldname由客户端决定,通过req.files数组方法
4) any 接收所有文件上传,通过req.files访问文件

ps:该实例基于nodejs v5.8,js部分使用到es6, web框架基于express,web模板esj-mate,所以你需要安装nodejs,同时通过npm install命令安装express,ejs-mate,multer模块.

1.app.js

"use strict"

const express = require('express');
const path = require('path');
const multer = require('multer'); let app = express();
let storage = multer.diskStorage({
//文件存储路径
destination: (req , file , cb )=>{
cb(null , path.join(__dirname , 'uploads'));
},
//修改上传文件的名字
//file 是个文件对象 ,fieldname对应在客户端的name属性
filename: (req , file , cb ) => {
cb( null, file.fieldname +'-' + Date.now());
}
}); let METHOD_MODE = { SINGLE:'single',ARRAY:'array' , ANY:"any"};
let isDest = false; //不是dest就是storage let obj = null; let multerobj = null;
if( isDest ){
multerobj = multer({
dest: path.join(__dirname,'uploads')
});
}else {
multerobj = multer({
storage: storage
});
}; //默认使用single方法,如果需要使用
//array和any和field等方法
//在index.html也需要做相应的修改
let mode = METHOD_MODE.SINGLE;
const FIELD_NAME = "_file";
let upload_multer ; (function(){
switch( mode ){
case METHOD_MODE.SINGLE: upload_multer = multerobj.single(FIELD_NAME);break;
case METHOD_MODE.ARRAY: upload_multer = multerobj.array(FIELD_NAME);break;
case METHOD_MODE.ANY: upload_multer = multerobj.any();break;
default:
upload_multer = null; break;
}
})(); if(upload_multer == null ){
throw new Error("exception");
} app.use('/public',express.static(path.join(__dirname , 'public')));
app.set('views',path.join(__dirname , "views"));
app.set('view engine','html');
app.engine('html',require('ejs-mate')); app.get('/' , (req ,res) =>{
res.render('index',{title:'multer: File Upload Demo'});
}); let objMulter = multer({storage : storage }); app.post('/upload', (req, res ) => {
upload_multer( req, res , function( err ){
if( mode == METHOD_MODE.ARRAY || mode == METHOD_MODE.ANY){
console.log( "file length: " + req.files.length );
}else if(mode == METHOD_MODE.SINGLE){
console.log(JSON.stringify( req.file ));
}
if(err) return res.json({issuccessful: 0, message: err });
else
return res.json({issuccessful: 1, message: "File is uploaded "});
});
}); app.listen(3000,()=>{console.log("server is running...")});

2.index.html

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title><%=title %> </title>
</head>
<body>
<div>
<form enctype="multipart/form-data" method="post" action="/upload">
File:<input type="file" id="_file" name="_file" style="width:400px;height:35px;"/>
<!-- 仅仅在使用multer。array时候 -->
<!-- <input type="file" id="_file1" name="_file" style="width:400px;height:35px;"/>
<input type="file" id="_file2" name="_file" style="width:400px;height:35px;"/> -->
<input type="submit" value="submit" style="width:100px;height:35px;" />
</form>
</div>
</body>
</html>

启动程序,打开cmd然后cd到工程目录,node app.js


node应用通过multer模块实现文件上传的更多相关文章

  1. 【node】---multer模块实现图片上传---【巷子】

    1.安装muterl第三方模块 cnpm install multer --save 2.使用 multer在解析完成后,会向request对象中添加一个body对象和一个file或者files对象( ...

  2. node.js使用express框架进行文件上传

    关于node.js使用express框架进行文件上传,主要来自于最近对Settings-Sync插件做的研究.目前的研究算是取得的比较好的进展.Settings-Sync中通过快捷键上传文件,其实主要 ...

  3. Node.js新手教程——怎样实现文件上传功能

    作者:zhanhailiang 日期:2014-11-16 本文将介绍怎样使用Node.js实现文件上传功能. 1. 初始化项目信息:npm init [root@~/wade/nodejs/node ...

  4. 使用Node.js的Express框架进行文件上传

    我们先创建一个Express项目,要使用文件上传的功能还需要下载multer模块. npm install --save multer 下面我们在public文件夹下创建upload.html,内容如 ...

  5. Node使用 Express框架,实现文件上传

    一 安装依赖包 npm install multer --save 二 客户端上传文件 <!DOCTYPE html> <html> <head> <meta ...

  6. nodejs使用multiparty模块实现文件上传(另附express.bodyParser()的说明)

    最近师弟师妹们在用formidable做文件上传的时候会出现form.parse()不会触发的问题,在stackoverflow也没有找到答案,反而是几个答案推荐使用multiparty来代替,因为那 ...

  7. 【nodejs】--express的中间件multer实现图片文件上传--【XUEBIG】

    Multer是nodejs中处理multipart/form-data数据格式(主要用在上传功能中)的中间件.该中间件不处理multipart/form-data数据格式以外的任何形式的数据 Tips ...

  8. node.js系列(实例):原生node.js+formidable模块实现简单的文件上传

    /** * 原生node.js结合formidable模块实现图片上传改名 * @Author:Ghost * @Date:2016/07/15 * @description: * 1.引入模块htt ...

  9. Node.js文件上传

    Node.js express使用Multer实现文件上传html部分 <div> <h3>文件上传:</h3> 选择一个文件上传: <br/> < ...

随机推荐

  1. MIPI D-PHY 总结

    Operating Modes: Control, High-Speed, and Escape 1.The Lane is only in High-Speed mode during Data b ...

  2. Java Struts2 的请求处理流程详解

    一.Struts2的处理流程: 客户端产生一个HttpServletRequest的请求,该请求被提交到一系列的标准过滤器(Filter)组建链中(如ActionContextCleanUp:它主要是 ...

  3. PHP用ajia代码写三级联动下拉

    下面是我做三级联动下拉的步骤以及逻辑 第一步:先做一个省市区表格 第二步:建个PHP页面显示用我是在<body>里放<div>用来接收要显示的省市区表格信息,里面嵌入jquer ...

  4. [kuangbin带你飞]专题十 匹配问题 二分图多重匹配

    二分图的多重匹配问题不同于普通的最大匹配中的"每个点只能有最多一条边" 而是"每个点连接的边数不超过自己的限定数量" 最大匹配所解决的问题一般是"每个 ...

  5. C#自定义泛型类绑定ComboBox控件

    C# WinForm ComboBox 自定义数据项 (ComboBoxItem ) WinForm下的ComboBox默认是以多行文本来设定显示列表的, 这通常不符合大家日常的应用, 因为大家日常应 ...

  6. 【ActionScript】ActionScript3.0对舞台组件的增删改查

    以一个样例来说明ActionScript3.0对舞台组件的增删改查 例如以下图: 在Flash执行的时候,通过脚本.斜向下生成text0-text9十个文本节点. 提供两个功能. 1.在右上角,用户输 ...

  7. 史上最简单的带流控功能的http server

    s.py import time import SimpleHTTPServer import SocketServer BYTES_PER_SECOND=160*1024 class MyHTTPR ...

  8. [React] React Fundamentals: with-addons - ReactLink

    It can be tedious to type out all the boilerplate needed to get the DOM and states in React to synch ...

  9. 怎样创建TWaver 3D的轮廓选中效果

    在一般的游戏中.物体的选中效果会是这样: TWaver 3D中,物体的默认的选中效果一般都是一个方方正正的外框.在HTML5的Mono版本号中,TWaver提供了轮廓线样式的选中效果. 通过例如以下代 ...

  10. android 34 ListView进阶

    public View getView(int position, View convertView, ViewGroup parent) {////convertView是一个缓存,每次返回一个la ...