我正在工作一个简单的文件上传网站,一直有麻烦坚持上传文件没有错误。我现在拥有的代码在一个要上传的文件小于~20KB时可以完美地工作,但是对于大于这个值但小于~1MB的文件,只上传了大约~20KB的文件(从而破坏了文件)。
对于大于1MB的文件,上载完全失败并返回502错误。我已经确定要增加multer FileSize/FieldSize限制,并且永远不会收到文件太大的错误。
当一个在~20KB-1MB之间的文件被上传,没有前端或后端错误,但multer似乎‘挂’在上传,从来没有达到上传回调函数。
编辑我已删除前端代码,因为这似乎是一个节点/配置错误
app.js文件(已删除无关代码)
const express = require('express');
const multer = require('multer');
const path = require('path');
const bodyParser = require('body-parser');
const glob = require('glob');
const fs = require('fs');
const app = express();
const PORT = process.env.PORT || 3000;
const storage = multer.diskStorage({
destination: function(req, file, callback) { callback(null, './public/file') },
filename: function(req, file, callback) { callback(null, req.fileCode + '-' + file.originalname) },
});
const upload = multer({storage: storage, limits: {fileSize: 1024 * 1024 * 1024, fieldSize: 10000000000}}).single('selectedFile');
app.use(bodyParser.json({ limit: '5mb', extended: true })); //added from user suggestions
app.use(bodyParser.urlencoded({ limit: '5mb', extended: true }));
app.use(express.static(path.join(__dirname, 'public', 'media', 'styles.css')));
app.use(express.static(path.join(__dirname, 'public', 'media', 'scripts.js')));
app.get(["/","/index.html.var"], (req, res) => {
res.sendFile(path.join(__dirname, 'public', 'index.html'));
});
app.post('/upload-file', function(req, res) {
let fileCode = genFileCode();
glob("**/public/file/" + fileCode + "*.*", function (err, files) {
if(files[0])
fileCode = genFileCode();
req.fileCode = fileCode;
console.log("check 1");
upload(req, res, function(e) {
console.log("check 2");
if(e)
console.log("error " + e);
else
console.log("no error");
});
res.send(fileCode);
});
});
^^502上载大于~1MB的任何文件时会出现错误
在后端,您的正文解析限制似乎小于1 MB。将以下行更改为服务器配置文件:
app.use(bodyParser.json({limit:“5MB”,extended:true}))
app.use(BodyParser.URlenCoded({Limit:“5MB”,Extended:true}))
你可以根据你的标准设定限制。
我已经发现了我的错误,如果有人偶然发现了这一点,并且处于与我相同的情况:
upload(req, res, function(e) {
console.log("check 2");
if(e)
console.log("error " + e);
else
console.log("no error");
});
res.send(fileCode);
在这里,app.js似乎在上传回调之前发送响应,并过早地结束文件上传。将res.send放置在回调中似乎已经解决了所有问题