node.js中的块数据记录

时间:2013-05-14 11:29:31

标签: node.js http express

我在http.request()

中的node.js中有以下函数
       res.on('data', function (chunk) {
    var sr="response: "+chunk;
    console.log(chunk);
    });

我在控制台中得到了这个

<Buffer 3c 3f 78 6d 6c 20 76 65 72 73 69 6f 6e 3d 22 31 2e 30 22 20 65 6e 63 6f
 64 69 6e 67 3d 22 75 74 66 2d 38 22 20 3f 3e 3c 72 65 73 75 6c 74 3e 3c 73 75 63
 ...>

但是当我使用它时:

res.on('data', function (chunk) {
    var sr="response: "+chunk;
    console.log(sr);
    });

我得到了一个正确的xml响应:

responose: .....xml responose.....

我不明白为什么我需要附加一个字符串来输出正确的响应。第一个代码中生成的响应是什么意思?

2 个答案:

答案 0 :(得分:6)

chunkBuffer,这是Node存储二进制数据的方式。

因为它是二进制数据,所以在正确显示之前需要将其转换为字符串(否则,console.log将显示其对象表示)。一种方法是将它附加到另一个字符串(第二个示例就是这样),另一种方法是在其上调用toString()

console.log(chunk.toString());

但是,我认为当chunk包含不完整的字符时,这可能会失败(UTF-8字符可能包含多个字节,但您无法保证chunk不是'{1}} t在这样一个字节串的中间切断。)

答案 1 :(得分:0)

Chunk只是一个缓冲区,其中数据存储在Binary中,因此你可以使用utf8进行字符编码,这将把数据输出为String,这就是你在创建readStream时需要做的事情。 / p>

var myReadStream = fs.createReadStream( __dirname + '/readme.txt', 'utf8');

myReadStream.on('data', function(chunk){
    console.log('new chunk received');
    console.log(chunk);
})