stream流 都是events.EventEmitter的一个实例,都可以来创建自定义事件(也就是说,流是一个事件的实例)

在nodejs中 对http的请求与响应都是用流来实现的,请求就是一个输入的流,响应就是一个输出的流

使用stream流,可以提高性能,前面说的读写文件,是一次性把文件放在内存中,这样就不大合适了,而stream流,是将读取的文件放在Buffer(缓存)中。就是一边放,一边处理,steam流有两个好处,就是处理数据和提高性能。

下面来实现一个流:

var fs = require('fs');

var myReadStream = fs.createReadStream(__dirname+"/readMe.txt","utf8");//创建一个读取流的实例

var data="";//创建一个变量来接收文件

myReadStream.on("data",function(chunk){//data是在接收数据的时候用的监听函数  当文件很大时,是把文件分成很多Buffer来接收的 所以这个函数可能执行多次
data+=chunk;
}) myReadStream.on("end",function(){//end是接收完毕后的监听函数
console.log(data);
})

上诉代码,如果不设置编码为utf8,data值将会为Buffer,看着是一串数字

当然,还可以另一种设置编码的方式:

var myReadStream = fs.createReadStream(__dirname+"/readMe.txt");//创建一个读取流的实例

myReadStream.setEncoding("utf8");//设置编码

var data="";//创建一个变量来接收文件

myReadStream.on("data",function(chunk){//data是在接收数据的时候用的监听函数  当文件很大时,是把文件分成很多Buffer来接收的 所以这个函数可能执行多次
data+=chunk;
}) myReadStream.on("end",function(){//end是接收完毕后的监听函数
console.log(data);
})

在原来的基础上写一个写入流:

var myReadStream = fs.createReadStream(__dirname+"/readMe.txt");//创建一个读取流的实例
var myWriteStream = fs.createWriteStream(__dirname+"/writeMe.txt");//创建一个写入流 myReadStream.setEncoding("utf8");//设置编码 myReadStream.on("data",function(chunk){//data是在接收数据的时候用的监听函数 当文件很大时,是把文件分成很多Buffer来接收的 所以这个函数可能执行多次
myWriteStream.write(chunk);//将读取到的片段写入,参数就是要写入的内容
}) myReadStream.on("end",function(){//end是接收完毕后的监听函数 })

写入流 还有一种用法

var myWriteStream = fs.createWriteStream(__dirname+"/writeMe.txt");//创建一个写入流

var writeData = "hello world";
myWriteStream.write(writeData);//写入
myWriteStream.end();//写入完之后调用end方法 (调用这个方法是 代表这个流结束了,如果不掉用这个流,这个流是结束不了的,finish方法不会触发)
myWriteStream.on("finish",function(){//加一个监听函数,监听撸结束后
console.log("finished");
})

管道的使用pipe

用管道来实现赋值文件会非常简单:

var fs = require('fs');

var myReadStream = fs.createReadStream(__dirname+"/readMe.txt");//创建一个读取流的实例
var myWriteStream = fs.createWriteStream(__dirname+"/writeMe.txt");//创建一个写入流
myReadStream.pipe(myWriteStream);//使用管道 将读取流和写入流连接到一起

下面来上一个真实的代码,读取文件,加密,压缩,然后写入

var crypto = require("crypto");//用来加密
var fs = require("fs");
var zlib = require("zlib");//用来压缩 var password = new Buffer(process.env.PASS || "password");
var encryptStream = crypto.createCipher('aes-256-cbc',password); var gzip = zlib.createGzip();
var readStream = fs.createReadStream(__dirname+"/readMe.txt");
var writeStream = fs.createWriteStream(__dirname+"/out.gz"); readStream//读取
.pipe(encryptStream)//加密
.pipe(gzip)//压缩
.pipe(writeStream)//写入
.on("finish",function(){//写入结束的回调
console.log("done");
})

下面将上面代码压缩出来的out.gz文件解压,解密,然后输出到终端

var crypto = require("crypto");//用来加密
var fs = require("fs");
var zlib = require("zlib");//用来压缩 var password = new Buffer(process.env.PASS || "password");
var decryptStream = crypto.createDecipher('aes-256-cbc',password); var gzip = zlib.createGunzip();//解压
var readStream = fs.createReadStream(__dirname+"/out.gz"); readStream//读取
.pipe(gzip)//解压
.pipe(decryptStream)//解密
.pipe(process.stdout)//输出到终端中 标准输出
.on("finish",function(){//解压后的回调
console.log("done");
})

上面的代码稍微更改一下,将解密,解压出来的文件写入到deOut.txt文件中

var crypto = require("crypto");//用来加密
var fs = require("fs");
var zlib = require("zlib");//用来压缩 var password = new Buffer(process.env.PASS || "password");
var decryptStream = crypto.createDecipher('aes-256-cbc',password); var gzip = zlib.createGunzip();//解压
var readStream = fs.createReadStream(__dirname+"/out.gz");
var writeStream = fs.createWriteStream(__dirname+"/deOut.txt"); readStream//读取
.pipe(gzip)//解压
.pipe(decryptStream)//解密
.pipe(writeStream)//将解密,解压的文件写入到deOut.txt文件中
.on("finish",function(){//解压后的回调
console.log("done");
})

小知识:

process.stdout.write("哈哈");

可以在终端打印出指定内容

nodejs基础(管道、流)实现:复制、压缩、加密、解压,解密,写入文件的更多相关文章

  1. python用模块zlib压缩与解压字符串和文件的方法

    摘自:http://www.jb51.net/article/100218.htm Python标准模块中,有多个模块用于数据的压缩与解压缩,如zipfile,gzip, bz2等等. python中 ...

  2. Ubuntu下压缩与解压各种文件的命令

    1.压缩与解压xz文件 (1)压缩 xz -z  filename (2)解压 xz -d  filename.xz 2.压缩与解压tar文件 (1)压缩 tar -cvf  filename(压缩到 ...

  3. Java基础-IO流对象之压缩流(ZipOutputStream)与解压缩流(ZipInputStream)

    Java基础-IO流对象之压缩流(ZipOutputStream)与解压缩流(ZipInputStream) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 之前我已经分享过很多的J ...

  4. 用DELPHI 开发压缩、解压、自解压、加密

    引 言:在日常中,我们一定使用过WINZIP.WINRAR这样的出名的压缩软件,就是我们开发软件过程中不免要遇到数据加密.数据压缩的问题!本文中就这一技术问题展开探讨,同时感谢各位网友的技巧,在我每次 ...

  5. 使用.Net自带的GZipStream进行流压缩与解压

    using System.IO; using System.IO.Compression; using System.Text; namespace CS.Utility { /// <summ ...

  6. 记录新项目中遇到的技术及自己忘记的技术点【DES加密解密,MD5加密,字符串压缩、解压,字符串截取等操作】

    一.DES加密.解密 #region DES加密解密 /// <summary> /// 进行DES加密 /// </summary> /// <param name=& ...

  7. python的shutil模块-文件的移动、复制、打包、压缩、解压等

    参考https://www.cnblogs.com/xiangsikai/p/7787101.html os模块提供了对目录或者文件的新建.删除.查看文件属性,还提供了对文件以及目录的路径操作,比如说 ...

  8. 文件操作工具类: 文件/目录的创建、删除、移动、复制、zip压缩与解压.

    FileOperationUtils.java package com.xnl.utils; import java.io.BufferedInputStream; import java.io.Bu ...

  9. Java的压缩、解压及压缩加密、解密解压 样例

    为了节约带宽.加快传送速度,http协议支持gzip的压缩,但假设我们的app与后台不是通过http协议通讯的.那么压缩.解压这个流程须要自己写.以下给出compress和decompress的代码: ...

  10. I/O操作之文件压缩与解压

    与文件压缩与解压相关的类在java.util.zip包下 实例 //文件压缩 import java.io.File; import java.io.FileInputStream; import j ...

随机推荐

  1. SQL Server系统函数:元数据函数

    原文:SQL Server系统函数:元数据函数 1.列的长度.列名 --列的长度 select COL_LENGTH('dbo.wct', --表名 'wcid') --列名 --列名 select ...

  2. Vs2019 C# .net core 将证书添加到受信任的根证书存储失败,出现以下错误:访问控制列表(ACL)结构无效

    https://www.cnblogs.com/xiyuan/p/10632579.html 使用 vs2017 创建一个 ASP.NET Core Web 应用程序 -> Ctrl + F5 ...

  3. ant Windows下环境变量配置 安装 编译

    下载 官网:[http://ant.apache.org/] 其他版本:[http://archive.apache.org/dist/ant/binaries/] 点击这个进入下载页面 Window ...

  4. 二、运行时JVM结构组成及作用

    二.运行时JVM结构组成及作用 程序计数器 是否共享:否,线程私有,每个线程有1个独立的程序计数器! 所处位置:线程私有的内部区域 生命周期:与线程绑定 主要作用: 当前线程执行字节码的行号指示器!  ...

  5. docker系列五之数据卷(volumn)

    docker数据卷(volumn) 一. 为什么需要数据卷 docker镜像是由多个文件系统(只读层)叠加而成,当我们启动一个容器的时候,docker的服务端会加载镜像的只读层,并在最顶层创建一个可读 ...

  6. Vue命名路由

    Vue命名路由 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  7. 移动端适配flexible.js

    npm install lib-flexible --save npm install px2rem-loader --save-dev

  8. MVC框架+vue+elementUI

    用自动化构建做的vue项目,因为是动态加载数据,在SEO优化时一直不如意,于是我们换了框架,用MVC框架,做成静态页面,但是原来的代码都是用vue和elementUI,为了快速的复用原来的代码,于是在 ...

  9. 通过Nginx统计网站的PV、UV、IP

    转载:通过Nginx统计网站的PV.UV.IP 概念 UV:独立访客:以cookie为依据,假设一台电脑装有3个不同的浏览器,分别打开同一个页面,将会产生3个UV.PV:访问量:页面每访问或刷新一次, ...

  10. nginx的so_keepalive和timeout相关小计

    KeepAlive 这里的keepalive是TCP的探活机制: [root@ ~]# sysctl -a |grep tcp_keepalive net.ipv4.tcp_keepalive_tim ...