nodejs文件上传组件multer使用
多图上传,发送端:
var express = require('express')
var rp = require('request-promise')
var fs = require("fs");
var app = express()
app.get('/send', function(req, res, next) {
    var options = {
        method: 'POST',
        uri: 'http://127.0.0.1:3000/profile',
        formData: {
            avatar: [fs.createReadStream("./ad.jpg"), fs.createReadStream("./222.png")]
        },
        headers: {
            // 'content-type': 'application/x-www-form-urlencoded'
        }
    };
    rp(options)
        .then(function(body) {
            // POST succeeded...
            res.send(body);
        })
        .catch(function(err) {
            // POST failed...
            res.send(err);
        });
});
app.listen(3001);
接收端:
var express = require('express')
var multer = require('multer')
var _ = require("lodash");
var app = express()
var storage = multer.diskStorage({
    //设置上传后文件路径,uploads文件夹会自动创建。
    destination: function(req, file, cb) {
        cb(null, './uploads')
    },
    //给上传文件重命名,获取添加后缀名
    filename: function(req, file, cb) {
        var fileFormat = (file.originalname).split(".");
        cb(null, file.fieldname + '-' + Date.now() + "." + fileFormat[fileFormat.length - 1]);
    }
});
var fileFilter = function(req, file, cb) {
        cb(null, false);   //这里设置为false则直接拒绝上传了,实际使用应为true
    }
    //添加配置文件到muler对象。
var upload = multer({
    storage: storage,
    fileFilter: fileFilter
});
var up = upload.array('avatar');
app.post('/profile', function(req, res, next) {
    // req.file 是 `avatar` 文件的信息\
    up(req, res, function(err) {
        if (err) {
            // An error occurred when uploading
            res.send(err);
            return
        }
        res.send("upload success");
        // Everything went fine
    })
});
app.post('/profile2', function(req, res, next) {
    // req.file 是 `avatar` 文件的信息
    console.log(req.body);
    res.json({ "succ": true, "msg": "请求成功" });
});
app.listen(3000);
nodejs文件上传组件multer使用的更多相关文章
- Express文件上传之Multer
		
Express文件上传之Multer Multer是一个nodejs中间件,用来处理http提交multipart/form-data,也就是文件上传.它是在busboy的基础上开发的. 在我看来,M ...
 - express文件上传中间件Multer详解
		
express文件上传中间件Multer详解 转载自:https://www.cnblogs.com/chengdabelief/p/6580874.html Express默认并不处理HTTP请 ...
 - Atitit..文件上传组件选型and最佳实践总结(3)----断点续传控件的实现
		
Atitit..文件上传组件选型and最佳实践总结(3)----断点续传控件的实现 1. 实现思路:::元插件,元设置... 1 2. 实现流程downzip,unzip,exec 1 3. Zip ...
 - Atitit..文件上传组件选型and最佳实践总结(2)----断点续传
		
Atitit..文件上传组件选型and最佳实践总结(2)----断点续传 1. 断点续传的原理 1 2. 如何判断一个插件/控件是否支持断点续传?? 1 3. 常用的组件选型结果::马 1 4. 自定 ...
 - 异步文件上传组件 Uploader
		
Uploader是非常强大的异步文件上传组件,支持ajax.iframe.flash三套方案,实现浏览器的全兼容,调用非常简单,内置多套主题支持 和常用插件,比如验证.图片预览.进度条等,广泛应用于淘 ...
 - 多文件上传组件FineUploader使用心得
		
原文 多文件上传组件FineUploader使用心得 做Web开发的童鞋都知道,需要经常从客户端上传文件到服务端,当然,你可以使用<input type="file"/> ...
 - ASP中文件上传组件ASPUpload介绍和使用方法
		
[导读]要实现该功能,就要利用一些特制的文件上传组件.文件上传组件网页非常多,这里介绍国际上非常有名的ASPUpload组件 1 下载和安装ASPUpload 要实现该功能,就要利用一些特制的文件上 ...
 - Atitit..文件上传组件选择and最佳实践的总结(2)----HTTP
		
Atitit..文件上传组件选型and最佳实践总结(2)----断点续传 1. 断点续传的原理 1 2. 怎样推断一个插件/控件是否支持断点续传?? 1 3. 经常使用的组件选型结果::马 1 4. ...
 - 文件上传组件FileUpload 以及邮箱搭建JavaMail
		
文件上传与下载 1.1 文件上传 案例: 注册表单/保存商品等相关模块! --à 注册选择头像 / 商品图片 (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 文件上传,要点: 前台: 1 ...
 
随机推荐
- php中的XML DOM(10)
			
1.PHP DOM (1) Php中的DOM跟javascript不一样,属性不用另外增加一个节点 2.主要类 DOMDocument :文档类 DOMNodeList :节点列表类 DOMNode ...
 - [bzoj3995] [SDOI2015]道路修建 线段树
			
Description 某国有2N个城市,这2N个城市构成了一个2行N列的方格网.现在该国政府有一个旅游发展计划,这个计划需要选定L.R两列(L<=R),修建若干条专用道路,使得这两列之间(包括 ...
 - c++ 多态总结
			
C++的多态性用一句话概括就是: 在基类的函数前加上virtual关键字,在派生类中重写该函数,运行时将会根据对象的实际类型来调用相应的函数. 如果对象类型是派生类,就调用派生类的函数:如果对象类型是 ...
 - jquery源码解析:addClass,toggleClass,hasClass详解
			
这一课,我们将继续讲解jQuery对元素属性操作的方法. 首先,我们先看一下这几个方法是如何使用的: $("#div1").addClass("box1 box2&quo ...
 - 数学规划求解器lp_solve超详细教程
			
前言 最近小编学了运筹学中的单纯形法.于是,很快便按奈不住跳动的心.这不得不让我拿起纸和笔思考着,一个至关重要的问题:如何用单纯形法装一个完备的13? 恰巧,在我坐在图书馆陷入沉思的时候,一位漂亮的小 ...
 - 实现函数 ToLowerCase()
			
/** * 实现函数 ToLowerCase(),该函数接收一个字符串参数 str, 并将该字符串中的大写字母转换成小写字母,之后返回新的字符串. * 输入: "Hello" * ...
 - AFNetworking 3.1.0 使用中某些知识点讲解
			
# POST / GET 请求 /*! 首先要知道,POST请求不能被缓存,只有 GET 请求能被缓存.因为从数学的角度来讲,GET 的结果是 幂等 的,就好像字典里的 key 与 value 就是 ...
 - 48.rocketMQ
			
一.简介 RocketMQ是阿里旗下的一款产品,分为开源版本和非开源版本.相比于ActiveMQ,RocketMQ支持顺序消费.事务机制.失败重试机制.消息可查询.消息订阅.较强的水平扩展能力.亿级堆 ...
 - LeetCode 795. Number of Subarrays with Bounded Maximum
			
问题链接 LeetCode 795 题目解析 给定一个数组A,左右范围L.R.求子数组的数量,要求:子数组最大值在L.R之间. 解题思路 子数组必须连续,利用最大值R对数组进行分段,设定变量 left ...
 - (C/C++) string / *char / int 基本轉換
			
網路上有許 string / *char / integer 基本轉換方式 string 與 *char 互相轉換的方法 /* string to *char */ string ssbuf1 = & ...