Node和http.get

时间:2016-06-18 16:35:30

标签: javascript node.js http

我正在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()和管道是如何工作的......

1 个答案:

答案 0 :(得分:6)

唯一的区别是你们两个人如何处理响应。您按块处理响应块并附加了等效于body的字符串。他们使用pipe发送可读流response并将其发送到可写流bl(缓冲区列表),该流可以等到可读流完成后再继续。当您订阅“数据”的发射器来处理响应块时,bl会在幕后执行此操作。

pipe是在可读流上调用的函数,它传递可写流的参数。

编辑:我刚刚注意到你的帖子的日期。很奇怪没有人回答这个......