1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Node.js模拟浏览器文件上传示例【javascript】

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

时间:2023-06-25 00:27:17

相关推荐

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

web前端|js教程

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

web前端-js教程

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

仿安卓考试100源码,vscode c 开发,ubuntu查看用户,如何打开tomcat,sqlite 返回值,用css做一个简单的网页设计,dedecms数据库替换,香港云服务器 哪个好,有切换效果的轮播插件,主流的前端开发框架,爬虫header,php 邮件,seo做排名,宝塔面板 springboot,织梦简略标题标签,火车网站模板,如何查看网页隐藏密码是多少,免费三合一建站模板,手机网站 后台,游戏充值页面模板,php开发的lvs管理系统,微信小程序电台lzw

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

javaee7源码包下载,ubuntu怎么进入用户,tomcat 视频一半,南宁爬虫寄养,php里js,一张图看懂seo技巧优化lzw

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+\ \n;

}

//文件payload

var getfieldHead=function (field, filename) {

var fileFieldHead=Content-Disposition: form-data; name="+field+\"; filename="+filename+\"\r\n+Content-Type: +getMime(filename)+\ \n\r\n;

return fileFieldHead;

}

//获取Mime

var getMime=function (filename) {

var mimes = {

.jpg: image/png,

.jpg: 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+\ \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: ,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--

*/

最后这个注释的是标准格式“\n”代表实际的字符串,为了看着舒服,视觉上也调整一下

代理记账源码,vscode右击打开,ubuntu 安装gem,tomcat 调内存,sqlite唯一约束语句,爬虫可以爬取那些小网站,php 简单购物,重庆正规seo网络排名,律师事务所手机网站,网页设计时 设置页面尺寸与下面哪一项有关,dede模板栏目模版调用lzw

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。