Node.js Stream

Posted 栗霖

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Node.js Stream相关的知识,希望对你有一定的参考价值。

Stream是一个抽象接口,Node中很多对象实现了这个接口,例如:http服务器发起请求的request对象就是一个Stream,还有stdout(标准输出)。

Node.js,Stream有四种流类型:

Readable-可读操作  Writable-可写操作  Duplex-可读可写操作  Transform-操作被写入数据,然后读出结果。

所有的Stream对象都是EventEmitter的实例。常用的事件有:

data-当有数据可读时触发  end-没有更多的数据可读时触发  error-在接收和写入过程中发生错误时触发  finish-所有数据已被写入到底层系统时触发。


 

从流中读取数据

var fs = require("fs");
var data = \'\';

//创建可读流
var readerStream = fs.createReadStream(\'input.txt\');

//设置编码为utf8
readerStream.setEncoding(\'UTF8\');

//处理流事件 -->data, end , and error
readerStream.on(\'data\', function(chunk) {
   data += chunk; 
})

readerStream.on(\'end\', function(){
   console.log(data); 
})

readerStream.on(\'error\', function(err) {
   console.log(err.stack); 
})

console.log("程序执行完毕");


 

写入流

创建main.js文件,代码如下:

var fs = require("fs");
var data = \'菜鸟教程官网地址:www.runoob.com\';

//创建一个可以写入的流,写入到文件output.txt中
var writerStream = fs.createWriteStream(\'output.txt\');

//使用utf8编码写入数据。
writerStream.write(data, \'UTF8\');

//标记文件末尾
writerStream.end();

//处理流事件 -->data, end ,and error
writerStream.on(\'finish\', function() {
    console.log("写入完成。");    
});

writerSteam.on(\'error\', function(err) {
    console.log(err.stack);    
});

console.log("程序执行完毕");


 

创建main.js文件,代码如下:
var fs = require("fs");

//创建一个可读流
var readerStream = fs.createReadStream(\'intput.txt\');

//创建一个可写流
var writerStream = fs.createrWriteStream(\'output.txt\');

//管道读写操作
//读取input.txt内容,并将内容写入到output.txt文件中。
readerSteam.pipe(writerStream);

console.log("程序执行完毕");


链式流

链式是通过连接输出流到另一个流并创建多个操作链的机制,链式流一般用于管道操作。

接下来我们就是用管道和链式来压缩和解压文件。

创建compress.js文件,代码如下:

var fs = require("fs");
var zlib = require("zlib");

//压缩input.txt文件为input.txt.gz
fs.createReadStream(\'input.txt\')
   .pipe(zlib.createGizp())
   .pipe(fs.createWriteStream(\'input.txt.gz\'));

console.log("文件压缩完成。");

var fs = require("fs");
var zlib = require(\'zlib\');

//解压input.txt.gz文件为inpu.txt
fs.createReadStream(\'input.txt.gz\')
   .pipe(zlib.createGunzip())
   .pipe(fs.createWriteStream(\'input.txt\'));

console.log("文件解压完成");

 

以上是关于Node.js Stream的主要内容,如果未能解决你的问题,请参考以下文章

关于 Node.js Stream API 的用法概述

Node.js 文件上传(Express 4、MongoDB、GridFS、GridFS-Stream)

Node.js Stream

Node.js中的代码AWS Lambda Package不会调用putRecord()来将数据添加到AWS Kinesis Firehose Stream中

Node.js:Stream(流)

Node.js Stream(流)