我试图解决一个问题几天,但无法理解一些事情。
我有一个使用 NodeJS 和 ExpressJS 创建的网站,为了处理表单,我使用 body-parser。
var adName = req.body.adName;
var adMessage = req.body.adMessage;
var phone = req.body.phone;
var rawPrice = req.body.price;
var rawCurrency = req.body.currency;
因此,我使用这种方法处理表单值。
但现在,我需要使用 node-formidable 来解析来自用户的图像。问题是,我可以用某种方式
仅对于图像和表单的正文解析器来说很强大?或者,任何人都可以帮助我理解如何处理表单并将值附加到我的变量吗?
您可能需要花一些时间来学习/练习这个强大的模块。看这个网址:https://github.com/felixge/node-formidable https://github.com/felixge/node-formidable
是的,formidable 可用于处理表单字段和文件上传,包括多个文件上传。 body-parser 中间件不处理多部分 -https://github.com/expressjs/body-parser https://github.com/expressjs/body-parser。在这种情况下,我会建议你使用强大的和 drop body-parser。
看看下面的快递应用程序是否可以帮助您。
var formidable = require('formidable'),
util = require('util'),
express = require('express'),
app = express();
app.set('port', process.env.PORT || 3600);
app.get('/', function (req, res) {
res.send(
'<form action="/upload" enctype="multipart/form-data" method="post">'+
'<input type="text" name="adName" placeholder="adName"><br>'+
'<input type="text" name="adMessage" placeholder="adMessage"><br>'+
'<input type="text" name="phone" placeholder="phone"><br>'+
'<input type="text" name="rawPrice" placeholder="rawprice"><br>'+
'<input type="text" name="rawCurrency" placeholder="rawcurrency"><br>'+
'<input type="file" name="upload" multiple="multiple"><br>'+
'<input type="submit" value="Upload">'+
'</form>'
);
});
app.post('/upload', function(req, res){
var form = new formidable.IncomingForm();
form.uploadDir = __dirname + "/data";
form.parse(req, function(err, fields, files) {
//fields is an object containing all your fields, do waht ever you want with them from here
//file is an object containing properties of your uploaded file
res.send(util.inspect({fields: fields, files: files}));
console.log('file uploaded : ' + files.upload.path + '/' + files.upload.name);
console.log('Fields : ' + fields.adName);//you can access all your fields
});
});
//starting server
app.listen(app.get('port'), function () {
console.log('Express is listening: http://localhost:%s;', app.get('port'));
});
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)