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代码要注意的几条规则
Sep 10 Javascript
js中根据字数截取字符串,不能截断url
Jan 12 Javascript
Javascript的各种节点操作实例演示代码
Jun 27 Javascript
jQuery动画效果-slideUp slideDown上下滑动示例代码
Aug 28 Javascript
javascript实现时间格式输出FormatDate函数
Jan 13 Javascript
JavaScript实现点击单选按钮改变输入框中文本域内容的方法
Aug 12 Javascript
手机端点击图片放大特效PhotoSwipe.js插件实现
Aug 24 Javascript
Vue计算属性的使用
Aug 04 Javascript
React进阶学习之组件的解耦之道
Aug 07 Javascript
vue-cli 构建骨架屏的方法示例
Nov 08 Javascript
vue实现计算器功能
Feb 22 Javascript
JS如何生成动态列表
Sep 22 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
PHP 开发环境配置(测试开发环境)
2010/04/28 PHP
php判断页面是否是微信打开的示例(微信打开网页)
2014/04/25 PHP
php实现给一张图片加上水印效果
2016/01/02 PHP
PHP中使用mpdf 导出PDF文件的实现方法
2018/10/22 PHP
php基于协程实现异步的方法分析
2019/07/17 PHP
childNodes.length与children.length的区别
2009/05/14 Javascript
javascript 读取xml,写入xml 实现代码
2009/07/10 Javascript
jquery zTree异步加载简单实例分享
2013/02/05 Javascript
原生js实现给指定元素的后面追加内容
2013/04/10 Javascript
JavaScript Math.ceil 方法(对数值向上取整)
2015/01/09 Javascript
js判断一个字符串是否包含一个子串的方法
2015/01/26 Javascript
JS实现网站菜单拖拽移位效果的方法
2015/09/24 Javascript
jQuery实现form表单元素序列化为json对象的方法
2015/12/09 Javascript
jQuery+css实现炫目的动态块漂移效果
2016/01/28 Javascript
特殊日期提示功能的实现方法
2016/06/16 Javascript
Jquery循环截取字符串的方法(多出的字符串处理成&quot;...&quot;)
2016/11/28 Javascript
Textarea输入字数限制实例(兼容iOS&amp;安卓)
2017/07/06 Javascript
分享Bootstrap简单表格、表单、登录页面
2017/08/04 Javascript
vue 项目如何引入微信sdk接口的方法
2017/12/18 Javascript
微信小程序实现滴滴导航tab切换效果
2018/07/24 Javascript
小程序日历控件使用方法详解
2018/12/29 Javascript
实例详解带参数的 npm script
2019/05/28 Javascript
详解ES6实现类的私有变量的几种写法
2021/02/10 Javascript
[01:35]2014DOTA2西雅图邀请赛 专访狐狸妈青春献给刀塔
2014/07/08 DOTA
Python模仿POST提交HTTP数据及使用Cookie值的方法
2014/11/10 Python
Python中为什么要用self探讨
2015/04/14 Python
python去除文件中重复的行实例
2018/06/29 Python
Python多继承原理与用法示例
2018/08/23 Python
python3.6生成器yield用法实例分析
2019/08/23 Python
奥兰多迪士尼门票折扣:Undercover Tourist
2018/07/09 全球购物
为什么group by 和order by会使查询变慢
2014/05/16 面试题
中医学专业自荐信范文
2014/04/01 职场文书
运动会口号16字
2014/06/07 职场文书
鼋头渚导游词
2015/02/05 职场文书
预备党员党支部意见
2015/06/02 职场文书
分享很少见很有用的SQL功能CORRESPONDING
2022/08/05 MySQL