所以我一直想知道如何在不使用express的情况下将图像保存到node.js服务器。(只是学习节点并希望自己更好地学习节点,而不用表达)。
到目前为止,我有一个表单,其中图像是我发送的唯一输入请求。这是我到目前为止在我的服务器上所做的,它没有记录任何内容。
if(req.method === 'POST') {
if (req.url === '/upload') {
req.on('error', function(e) {
console.log('Problem with request: ' + e.message);
});
res.writeHead(200, {'Content-Type': 'image/jpg; charset=utf8'});
req.on('data', function (chunk) {
fs.writeFile(__dirname + "/uploads/dada.jpg", chunk, function(err) {
if(err) {
console.log(err);
} else {
console.log("The file was saved!");
}
});
});
}
}
这是我的表格:
<form method="post" action="/upload" enctype="multipart/form-data">
编辑:我解决了大部分问题,但该文件只保存为图片,但无法查看。 (我猜的内容类型有问题,但不知道如何修复它) Here是我整个应用程序的小提琴。我知道我需要在不同的模块中将它分开,但我稍后会这样做
答案 0 :(得分:2)
我完全忘记了这个老问题,但现在我看到它有很多观点,这里是我找到的解决方案:
var port = 1357;
var http = require('http'),
path = require('path'),
mime = require('mime'),
fs = require('fs'),
GUID = require('GUID'),
formidable = require('formidable'),
util = require('util');
var app = http.createServer(function (req, res) {
if (req.method === 'POST') {
if (req.url === '/upload') {
req.on('error', function (e) {
console.log('Problem with request: ' + e.message);
});
var fileDirectory = __dirname + '/db/',
form = new formidable.IncomingForm();
form.keepExtensions = true;
form.uploadDir =fileDirectory;
form.parse(req, function (err, fields, files) {
if (err) throw (err);
var pic = JSON.stringify(util.inspect(files)),
upIndx = pic.indexOf('db'),
path = pic.slice(upIndx + 6, upIndx + 42);
res.writeHead(200, {
'Content-Type': 'text/html'
});
fs.readFile('views/index.html', function (err, page) {
res.writeHead(200, {
'Content-Type': 'text/html'
});
res.write(page);
res.write('<div>Download Link: </div><div>' + fileDirectory + path + '</div>');
res.end();
});
});
}
} else {
//not important for question, handle other request
}
});
app.listen(port);
console.log('Server running on port: ' + port)