【发布时间】:2014-10-20 07:23:26
【问题描述】:
我的源代码有问题,但我不知道是什么问题 - 请帮忙。我一直在寻找一些解决方案,找到了一些并根据它们更新了源代码,但没有帮助。
var express = require('express');
var fs = require('fs');
var bodyParser = require('body-parser');
var app = express()
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
var form = "<!DOCTYPE HTML><html><body>" +
"<form method='post' action='/upload' enctype='multipart/form-data'>" +
"<input type='file' name='image' id='image'/>" +
"<input type='submit' /></form>" +
"</body></html>";
app.get('/', function(req, res){
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(form);
});
app.post('/upload', function(req, res){
fs.readFile(req.files.image.path, function(err, data){
var imageName = req.files.image.name
if(!imageName){
console.log("There was an error");
res.redirect('/');
res.end();
}else{
var newPath = __dirname + "/uploads/fullsize/" + imageName;
fs.writeFile(newPath, data, function(err){
res.redirect("/uploads/fullsize/" + imageName);
});
}
});
});
app.listen(8080);
【问题讨论】:
-
尝试
req.body.files而不是req.files。如果您从 HTTP 请求发送一些数据,它将存储在请求正文中。 stackoverflow.com/questions/11625519/… -
同样的问题 - 当我把控制台 req.body 它是空的。请注意,它是多部分而不是 json。
标签: node.js image file-upload express multipartform-data