您的位置:首页 > 理论基础 > 计算机网络

nodejs自带的请求方法--http.request

2017-10-19 15:10 211 查看
本文是接着前面的,用nodejs获取到本地文件的内容之后的操作。

当获取完本地文件的内容后,假设内容为相关的url链接,用ajax请求获取数据,这种方法是基于浏览器的,所以运行效率都是依赖于浏览器。

但是用nodejs也可以实现获取数据,并且是基于操作系统的,效率上远远超过浏览器方式。

本文使用的http.request()方法的API

下面来细说如何操作:

1.先声明一个通用方法来进行数据的请求

var http=require("http"); //导入需要的http库
function HttpRequest(option,callback){  //option设置请求的请求头,callback请求数据回调函数
var con='';  //存放请求后的数据
var req=http.request(option,function(res){  //http。request方法用于获取数据
res.setEncoding('utf-8');  //设置响应字符集
var resListener=setTimeout(function(){  //添加响应监听,20s后没有响应信息返回自动结束响应,并返回空数据
res.destroy(); //结束响应
con='';
callback(con);
},20000);
res.on('data',function(chuck){ //响应返回数据,并接受
if(chuck) con+=chuck;
}).on('end',function(){ //数据返回完毕
clearTimeout(resListener);
callback(con);
});
});
req.on('error',function(e){ //响应出错调用函数
console.log('错误为:'+e.message);
});
req.write(''); //发送请求
req.end(); //结束请求
}
2.写一个方法调用上面的方法:

function doEngine(data,callback){
var option={ //设置请求头信息
host:data.host, //域名
path:data.path, //资源地址
method:'GET', //请求方式
headers:{ //请求头信息
'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
'User-Agent':'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.79 Safari/537.36'
}
}
HttpRequest(option,function(obj){
callback(obj);
});
}


3.写一个主函数运行:

function run(data){
if(data){
//data= ....(data); 对数据进行适当的处理
doEngine(data,function(obj){
if(obj){
//对返回的数据进行相应的处理,不细说,根据实际情况而定
}
});
}

}


4.最后调用之前写的getContent()方法来获取要请求的请求头信息

nodeJS中大文件读写操作--Stream流

getContent(rs,run);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐