zoukankan      html  css  js  c++  java
  • 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);
    
  • 相关阅读:
    Spring cloud实现服务注册及发现
    使用spring cloud实现分布式配置管理
    spring cloud教程之使用spring boot创建一个应用
    7天学会spring cloud教程
    微服务开发的12项要素
    一句话概括下spring框架及spring cloud框架主要组件
    翻译-服务注册与发现
    翻译-微服务API Gateway
    微服务分布式事务的一些思考
    解决不能正常访问workerman的问题
  • 原文地址:https://www.cnblogs.com/vipzhou/p/6612632.html
Copyright © 2011-2022 走看看