nodejs 實(shí)現(xiàn)模擬form表單上傳文件
以前項(xiàng)目里有這個(gè)方法,最近在客戶那里出問題了,同事說,這個(gè)方法從來就沒管用過,SO,用了一天時(shí)間把這個(gè)方法給搞出來了(覺得花費(fèi)的時(shí)間長(zhǎng)了點(diǎn)),分享之。
代碼及測(cè)試用例:
var http = require('http'); var path = require('path'); var fs = require('fs'); function postFile(fileKeyValue, req) { var boundaryKey = Math.random().toString(16); var enddata = '\r\n----' + boundaryKey + '--'; var files = new Array(); for (var i = 0; i < fileKeyValue.length; i++) { var content = "\r\n----" + boundaryKey + "\r\n" + "Content-Type: application/octet-stream\r\n" + "Content-Disposition: form-data; name=\"" + fileKeyValue[i].urlKey + "\"; filename=\"" + path.basename(fileKeyValue[i].urlValue) + "\"\r\n" + "Content-Transfer-Encoding: binary\r\n\r\n"; var contentBinary = new Buffer(content, 'utf-8');//當(dāng)編碼為ascii時(shí),中文會(huì)亂碼。 files.push({contentBinary: contentBinary, filePath: fileKeyValue[i].urlValue}); } var contentLength = 0; for (var i = 0; i < files.length; i++) { var stat = fs.statSync(files[i].filePath); contentLength += files[i].contentBinary.length; contentLength += stat.size; } req.setHeader('Content-Type', 'multipart/form-data; boundary=--' + boundaryKey); req.setHeader('Content-Length', contentLength + Buffer.byteLength(enddata)); // 將參數(shù)發(fā)出 var fileindex = 0; var doOneFile = function(){ req.write(files[fileindex].contentBinary); var fileStream = fs.createReadStream(files[fileindex].filePath, {bufferSize : 4 * 1024}); fileStream.pipe(req, {end: false}); fileStream.on('end', function() { fileindex++; if(fileindex == files.length){ req.end(enddata); } else { doOneFile(); } }); }; if(fileindex == files.length){ req.end(enddata); } else { doOneFile(); } } //測(cè)試用例 //http://nodejs.org/api/http.html#http_http_request_options_callback var files = [ {urlKey: "file1", urlValue: "E:\\DFBF.jpg"}, {urlKey: "file2", urlValue: "E:\\1.jpg"}, {urlKey: "file3", urlValue: "E:\\Pro 空格 中文.mp3"} ] var options = { host: "localhost", port: "8908" , method: "POST", path: "/Home/Upload" } var req = http.request(options, function(res){ console.log("RES:" + res); console.log('STATUS: ' + res.statusCode); console.log('HEADERS: ' + JSON.stringify(res.headers)); //res.setEncoding("utf8"); res.on("data", function(chunk){ console.log("BODY:" + chunk); }) }) req.on('error', function(e){ console.log('problem with request:' + e.message); console.log(e); }) postFile(files, req); console.log("done");
服務(wù)端測(cè)試,用mvc在home控制器寫了個(gè)upload方法,并遍歷上傳的文件將其保存在硬盤上了。
只是上傳大文件會(huì)有問題,估計(jì)是需要服務(wù)器進(jìn)行配置,暫且不管。
服務(wù)端方法(寫在了Home控制器下)
[HttpPost] public string Upload() { //HttpPostedFileBase file = this.Request.Files["file"]; //file.SaveAs(file.FileName); foreach (string file in this.Request.Files) { this.Request.Files[file].SaveAs(@"E:\新建文件夾\" + this.Request.Files[file].FileName); } return @"保存成功 路徑:E:\新建文件夾\"; }
運(yùn)行腳本:
node nodejsPostFile.js
運(yùn)行結(jié)果:
相關(guān)文章
Sublime Text3 配置 NodeJs 環(huán)境的方法
大家都知道,Sublime Text 安裝插件一般從 Package Control 中直接安裝即可,當(dāng)我安裝 node js 插件時(shí)候,直接通過Package Control 安裝,雖然插件安裝成功了,但是找不到配置文件 Nodejs.sublime-build 來更改一些配置2020-05-05Mac OS X 系統(tǒng)下安裝和部署Egret引擎開發(fā)環(huán)境
之前的文章,我們已經(jīng)介紹了Windows 系統(tǒng)下安裝和部署Egret的開發(fā)環(huán)境,那么,這篇文檔中,我們主要介紹在Mac環(huán)境中安裝Egret以及部署2014-09-09IDEA中配置node.js的實(shí)現(xiàn)步驟
在IDEA中,如果要在安裝在遠(yuǎn)程主機(jī)或虛擬環(huán)境中的Node.js上運(yùn)行和調(diào)試應(yīng)用程序,則需要配置遠(yuǎn)程N(yùn)ode.js解釋器,本文主要介紹了IDEA中配置node.js的實(shí)現(xiàn)步驟,感興趣的可以了解一下2023-12-12