Node.js模拟浏览器文件上传示例


Posted in Javascript onMarch 26, 2014

OSChina上发过了,那个也是我的,现在放到这来,哈哈

这段代码只能一次上传一个文件~~

var path=require("path"); 
var fs=require("fs"); 
var http=require("http"); //post值payload 
var getfield=function(field, value) { 
return 'Content-Disposition: form-data; name="'+field+'"\r\n\r\n'+value+'\r\n'; 
} 
//文件payload 
var getfieldHead=function (field, filename) { 
var fileFieldHead='Content-Disposition: form-data; name="'+field+'"; filename="'+filename+'"\r\n'+'Content-Type: '+getMime(filename)+'\r\n\r\n'; 
return fileFieldHead; 
} 
//获取Mime 
var getMime=function (filename) { 
var mimes = { 
'.png': 'image/png', 
'.gif': 'image/gif', 
'.jpg': 'image/jpeg', 
'.jpeg': 'image/jpeg', 
'.js': 'appliction/json', 
'.torrent': 'application/octet-stream' 
}; 
var ext = path.extname(filename); 
var mime = mimes[ext]; 
mime=!!mime?mime:'application/octet-stream'; 
return mime; 
} 
//获取边界检查随机串 
var getBoundary=function() { 
var max = 9007199254740992; 
var dec = Math.random() * max; 
var hex = dec.toString(36); 
var boundary = hex; 
return boundary; 
} 
//获取boundary 
var getBoundaryBorder=function (boundary) { 
return '--'+boundary+'\r\n'; 
} 
//字段格式化 
function fieldPayload(opts) { 
var payload=[]; 
for(var id in opts.field){ 
payload.push(getfield(id,opts.field[id])); 
} 
payload.push(""); 
return payload.join(getBoundaryBorder(opts.boundary)); 
} 
//post数据 
function postRequest (opts) { 
filereadstream(opts,function (buffer) { 
var options=require('url').parse(opts.url); 
var Header={}; 
var h=getBoundaryBorder(opts.boundary); 
var e=fieldPayload(opts); 
var a=getfieldHead(opts.param,opts.file); 
var d="\r\n"+h; 
Header["Content-Length"]=Buffer.byteLength(h+e+a+d)+buffer.length; 
Header["Content-Type"]='multipart/form-data; boundary='+opts.boundary; 
options.headers=Header; 
options.method='POST'; 
var req=http.request(options,function(res){ 
var data=''; 
res.on('data', function (chunk) { 
data+=chunk; 
}); 
res.on('end', function () { 
console.log(res.statusCode) 
console.log(data); 
}); 
}); 
req.write(h+e+a);log.diy(h+e+a+buffer+d); 
req.write(buffer); 
req.end(d); 
}); 
} 
//读取文件 
function filereadstream(opts, fn) { 
var readstream = fs.createReadStream(opts.file,{flags:'r',encoding:null}); 
var chunks=[]; 
var length = 0; 
readstream.on('data', function(chunk) { 
length += chunk.length; 
chunks.push(chunk); 
}); 
readstream.on('end', function() { 
var buffer = new Buffer(length); 
for(var i = 0, pos = 0, size = chunks.length; i < size; i++) { 
chunks[i].copy(buffer, pos); 
pos += chunks[i].length; 
} 
fn(buffer); 
}); 
} 
//各类设置 
var opt={ 
"url":"http://xxxx.xx",//url 
"file":"00.jpg",//文件位置 
"param":"file",//文件上传字段名 
"field":{//其余post字段 
"client":"1", 
"title":"ok" 
}, 
"boundary":"----WebKitFormBoundary"+getBoundary() 
} 
postRequest(opt); 
/* 
------WebKitFormBoundaryuzKmkAovUuYsQ1Dt\r\n 
Content-Disposition: form-data; name="file"; filename="00.jpg"\r\n 
Content-Type: application/octet-stream 
\r\n 
\r\n +file\r\n 
------WebKitFormBoundaryuzKmkAovUuYsQ1Dt\r\n 
Content-Disposition: form-data; name="fieldName" 
\r\n 
\r\n +value\r\n 
------WebKitFormBoundaryuzKmkAovUuYsQ1Dt-- 
*/

最后这个注释的是标准格式“\r\n”代表实际的字符串,为了看着舒服,视觉上也调整一下
Javascript 相关文章推荐
js form action动态修改方法
Nov 04 Javascript
js 未结束的字符串常量错误解决方法
Jun 13 Javascript
解析Javascript小括号“()”的多义性
Dec 03 Javascript
详解Vue Elememt-UI构建管理后台
Feb 27 Javascript
Vue.js中关于侦听器(watch)的高级用法示例
May 02 Javascript
vue项目引入字体.ttf的方法
Sep 28 Javascript
vue实现条件判断动态绑定样式的方法
Sep 29 Javascript
angular4强制刷新视图的方法
Oct 09 Javascript
微信小程序使用npm支持踩坑
Nov 07 Javascript
vue在自定义组件中使用v-model进行数据绑定的方法
Mar 25 Javascript
vue keep-alive列表页缓存 详情页返回上一页不刷新,定位到之前位置
Nov 26 Javascript
js+for循环实现字符串自动转义的代码(把后面的字符替换前面的字符)
Dec 24 Javascript
JavaScript关闭当前页面(窗口)不带任何提示
Mar 26 #Javascript
JavaScript数字和字符串转换示例
Mar 26 #Javascript
jquery实现瀑布流效果分享
Mar 26 #Javascript
jquery实现效果比较好的table选中行颜色
Mar 25 #Javascript
Jquery对数组的操作技巧整理
Mar 25 #Javascript
常用的几段javascript代码分享
Mar 25 #Javascript
捕获和分析JavaScript Error的方法
Mar 25 #Javascript
You might like
常用星际术语索引(新手指南)
2020/03/04 星际争霸
国外比较好的几个的Php开源建站平台小结
2010/04/22 PHP
php数字转汉字代码(算法)
2011/10/08 PHP
需要注意的几个PHP漏洞小结
2012/02/05 PHP
php+js iframe实现上传头像界面无跳转
2014/04/29 PHP
php实现贪吃蛇小游戏
2016/07/26 PHP
thinkphp3.2中实现phpexcel导出带生成图片示例
2017/02/14 PHP
CodeIgniter框架数据库基本操作示例
2018/05/24 PHP
使用laravel和ajax实现整个页面无刷新的操作方法
2019/10/03 PHP
PHP 面向对象程序设计之类属性与类常量实现方法分析
2020/04/13 PHP
一个符号插入器 中用到的js代码
2007/09/04 Javascript
JS 参数传递的实际应用代码分析
2009/09/13 Javascript
CSS和Javascript简单复习资料
2010/06/29 Javascript
javascript级联下拉列表实例代码(自写)
2013/05/10 Javascript
JS实现QQ图片一闪一闪的效果小例子
2013/07/31 Javascript
jquery实现的Banner广告收缩效果代码
2015/09/02 Javascript
微信js-sdk上传与下载图片接口用法示例
2016/10/12 Javascript
JavaScript中Promise的使用详解
2017/02/26 Javascript
微信小程序 动态绑定数据及动态事件处理
2017/03/14 Javascript
[03:12]2016完美“圣”典风云人物:单车专访
2016/12/02 DOTA
Python上传package到Pypi(代码简单)
2016/02/06 Python
整理Python 常用string函数(收藏)
2016/05/30 Python
python redis 批量设置过期key过程解析
2019/11/26 Python
Python reversed函数及使用方法解析
2020/03/17 Python
一文读懂Python 枚举
2020/08/25 Python
python实现自动打卡的示例代码
2020/10/10 Python
HTML5 LocalStorage 本地存储刷新值还在
2017/03/10 HTML / CSS
日本高岛屋百货购物网站:TAKASHIMAYA
2019/03/24 全球购物
员工保密承诺书
2014/05/28 职场文书
超市促销活动总结
2014/07/01 职场文书
弄虚作假心得体会
2014/09/10 职场文书
个人先进事迹总结
2015/02/26 职场文书
违反纪律检讨书范文
2015/05/07 职场文书
中学生打架检讨书之500字
2019/08/06 职场文书
详解Django的MVT设计模式
2021/04/29 Python
mysql 子查询的使用
2022/04/28 MySQL