使用formidable模块处理multipart/form-data的数据上传轻松加easy。
但由于开始学的时候,使用以下代码传输post数据,导致formidable的parse方法不会解析请求
(代码处于http的createServer的监听器里面)
request.addListener('data', function(postDataChunk){
postData += postDataChunk;
});
request.addListener("end", function() {
postData = querystring.parse(postData);
router(options);
});
查了下官方文档,看到request的pause方法有这么一个解释
Pauses request from emitting events. Useful to throttle back an upload.
意思就是说,要上传文件,需要使用pause先暂停请求,上传完毕后再让请求继续吧
这样做上传可行,不过好像太麻烦了。。。
一种简单的做法是,将以上传输post数据的代码去掉,完全由formidable构建post数据就好了~
这样子上传就不会产生冲突了,如:
form = new formidable.IncomingForm();
form.on('error', function(err) {
console.log('formidabel error : ' + err);
request.resume();
}).on('field', function(field, value) {
if (form.type == 'multipart') { //有文件上传时 enctype="multipart/form-data"
if (field in postData) { //同名表单 checkbox 返回array 同get处理
if (helper.isArray(postData[field]) === false) {
postData[field] = [postData[field]];
}
postData[field].push(value);
return;
}
}
postData[field] = value;
});
var options = {
handle: handler,
pathname: pathname,
response: response,
request: request,
getData: getData
};
if(request.method == 'POST'){
form.parse(request, function(err, fields, files){
err && console.log('formidabel error : ' + err);
options.postData = postData;
options.files = files;
options.form = form;
router(options);
});
}else{
router(options);
}