NODE_多文件上传

安装依赖

npm i express
npm i multer

单文件上传

修改多文件上传代码
在这里插入图片描述
node.js

app.post('/upload', upload.single('file'), function (req, res, next) {
    req.files.forEach((item,i) => {
        console.log(item);
    })
    res.send('上传成功!')
});

前端代码

let formData = new FormData();
formData.append('file', this.fileList[0].file)
axios({
    method: 'post',
    url: 'http://127.0.0.1:3000/upload',
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
        'X-Requested-With': 'XMLHttpRequest'
    },
    data: formData
}).then((result) => {

}).catch((err) => {

});

多文件上传

node.js

var fs = require('fs');
var express = require('express');
var multer = require('multer');
var bodyParser = require('body-parser');

var app = express();

//跨域处理
var allowCrossDomain = function (req, res, next) {
    res.header('Access-Control-Allow-Origin', '*');
    res.setHeader('Access-Control-Allow-Methods', '*');
    res.setHeader('Access-Control-Allow-Headers', '*');
    next();
};
app.use(allowCrossDomain);
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));

/**
 * 重命名图片后缀
 */
var storage = multer.diskStorage({
    destination: function (req, file, cb) {
        cb(null, 'public/upload/');
    },
    filename: function (req, file, cb) {
        var fileFormat = file.originalname.split('.');
        cb(null, file.fieldname + '-' + Date.now() + '.' + fileFormat[fileFormat.length - 1]);
    },
});
var upload = multer({ storage: storage });
// var upload = multer({ dest: 'upload/' });
// 多图上传
app.post('/upload', upload.array('file', 8), function (req, res, next) {
    req.files.forEach((item,i) => {
        console.log(item);
    })
    res.send('上传成功!')
});

app.listen(3000, () => {
    console.log('服务启动3000端口...');
});

前端代码

let formData = new FormData();
this.fileList.forEach(item => {
    console.log(item);
    formData.append('file', item.file)
});
axios({
    method: 'post',
    url: 'http://127.0.0.1:3000/upload',
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
        'X-Requested-With': 'XMLHttpRequest'
    },
    data: formData
}).then((result) => {

}).catch((err) => {

});

前端请求数据

  • file
    在这里插入图片描述

后端接收到数据

  • req.files
    在这里插入图片描述
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值