只是如今主要用nodejs作后端了,因此记录一些上传文件的使用方法。javascript
上传文件的主要方式:html
一、form上传,优势是方便,缺点是无法回调,上传后返回的数据无法处理java
二、ajax上传,优势是可控制,有回调,缺点是不太方便node
用form上传,express后端接收,有不少插件,如formidable。可是没有回调。ajax
用ajaxFileUpload上传,express后端接收。看着像是ajax上传,其实中间会生成form multipart/form-data,因此能够使用multer接收,还有回调,确实挺不错的。express
一、form上传json
示例已经归档后端
二、ajax上传:使用ajaxfileupload上传,nodejs后端接受。post
htmlurl
<form> <input type='file' value='文件导入' id='csv_import' name='csv_import'/> <input type='button' value='上传' id='csv_upload' name='csv_upload'/> </form> // form不须要添加其余属性 // input name和id保持一致
js
$.ajaxFileUpload({ url: '/csvUpload', type: 'post', secureuri: false, fileElementId: 'csv_import', data: { "userId": 123 }, dataType: 'json', success: function(data, status){ debugger }, error: function(data, status, e){ debugger } }); // 修改fileElementId
nodejs
var form = new multiparty.Form(); form.parse(req, function(err, fields, files){ if(err){ console.log('parse error:'+err); }else{ var input_file = files.csv_import[0]; var uploaded_path = input_file.path; var buf = new Buffer(1024*input_file.size); // 获取文件的内容,做为一个base,这里只是读取文件的内容,并无存储 fs.open(uploaded_path, 'r+', function(err, fd) { if (err) { return console.error(err); } fs.read(fd, buf, 0, buf.length, 0, function(err, bytes){ if (err){ console.log(err); } var a = buf.slice(0, bytes).toString().split('\r\n'); var b = a.map(function(a_item){ return a_item.split(','); }) console.log(util.inspect({b: b})); }); }); } }) // 须要安装multiparty // files.csv_import中的csv_import与id保持一致
// csv_import是id
注意:后端返回数据的方式
res.send(JSON.stringify({ code: 0, msg: '导入成功' }));
使用ajaxfileupload和multiparty上传文件时,碰到了一个问题:上传后直径跳转到/a?file_upload=...,并无按照res.redirect('/')来执行,好奇怪;success error也没有捕获到返回的数据。