NODE_多文件上传

这篇博客介绍了如何使用Node.js的Express和Multer库实现多文件上传功能,包括设置存储路径、重命名文件以及处理上传请求。前端部分使用了Axios库和FormData来构造上传请求。同时,博客还展示了前端和后端的代码示例,帮助开发者理解整个上传流程。
摘要由CSDN通过智能技术生成

安装依赖

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
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值