本文是接着前面的,用nodejs获取到本地文件的内容之后的操作。
当获取完本地文件的内容后,假设内容为相关的url链接,用ajax请求获取数据,这种方法是基于浏览器的,所以运行效率都是依赖于浏览器。
但是用nodejs也可以实现获取数据,并且是基于操作系统的,效率上远远超过浏览器方式。
下面来细说如何操作:
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()方法来获取要请求的请求头信息
getContent(rs,run);