我正在nodeschool的研讨会上学习节点。研讨会的名称是
learnyounode,问题编号8. HTTP COLLECT 。
问题是:
编写一个程序,对提供给您的URL执行HTTP GET请求
作为第一个命令行参数。从服务器收集所有数据(不是
只是第一个"数据"事件)然后写两行到控制台
(标准输出)。
你写的第一行应该只是一个表示数字的整数
从服务器收到的字符数。第二行应该包含
完整服务器发送的字符串。
我提交的答案如下。
var http = require('http');
var url = process.argv[2];
http.get(url,function(res){
var body = '';
res.on('error',function(err){
console.error(err);
})
res.on('data',function(chunk){
body+=chunk.toString();
});
res.on('end',function(){
console.log(body.length);
console.log(body);
});
});
虽然他们提供的答案是,
var http = require('http')
var bl = require('bl')
http.get(process.argv[2], function (response) {
response.pipe(bl(function (err, data) {
if (err)
return console.error(err)
data = data.toString()
console.log(data.length)
console.log(data)
}))
})
我想知道这两个代码之间的区别。
并请解释http.get()和管道是如何工作的......
答案 0 :(得分:6)
唯一的区别是你们两个人如何处理响应。您按块处理响应块并附加了等效于body
的字符串。他们使用pipe
发送可读流response
并将其发送到可写流bl
(缓冲区列表),该流可以等到可读流完成后再继续。当您订阅“数据”的发射器来处理响应块时,bl
会在幕后执行此操作。
pipe
是在可读流上调用的函数,它传递可写流的参数。
编辑:我刚刚注意到你的帖子的日期。很奇怪没有人回答这个......