Buffer

用来保存原始数据

(logo.png)

以下代码读取logo.png为buffer类型

然后将buffer转化为string,新建png

可以将字符串配置: data:image/png;Base64,Buffer.toString()

var fs = require('fs')

fs.readFile('logo.png',function(err,origin_buffer){
console.log('origin_buffer是否Buffer格式:'+Buffer.isBuffer(origin_buffer))
//console.log('读取到origin_buffer:' + origin_buffer)
//创建文件
fs.writeFile('log_buffer.png',origin_buffer,function(err){
if(err) console.log(err)
}) //var base84Image = new Buffer(origin_buffer).toString('base64')
//转为字符串
var base64Image = origin_buffer.toString('base64') console.log('字符串base64Image:' + base64Image) var decodedImage = new Buffer(base64Image, 'base64') //console.log('编码decodedImage:'+decodedImage)
//console.log('比较origin_buffer和decodedImage:' + Buffer.compare(origin_buffer,decodedImage)) fs.writeFile('logo_decoded.png',decodedImage,function(err){
if(err) console.log(err)
}) })

Stream

暂存和移动数据

通过stream直接copy图片


var fs = require('fs')
var source = fs.readFileSync('../buffer/logo.png') fs.writeFileSync('stream_copy.png',source)

stream读操作触发事件

stream的读取会触发事件,通过监听可以实现许多功能

stream事件每次传输 64kb


var fs = require('fs') var readStream = fs.createReadStream('xpg.mp3')
var n=0 //数据传递过程中触发,监听data事件
readStream
.on('data', function(chunk){
n++
console.log('data emits')
console.log('是否以Buffer格式传递?:'+Buffer.isBuffer(chunk))
//console.log(chunk.toString('utf8'))
//
readStream.pause()//暂停
console.log('data pause')
setTimeout(function(){
console.log('data pause end')
readStream.resume()//重新启动
},10)
})
.on('readable',function(){
//文件可读
console.log('data readable')
})
.on('end', function(){
console.log(n)
//数据传递事件,同时触发目标不可写
console.log('data end')
})
.on('close',function(){
//整个stream关闭结束
console.log('data close')
})
.on('error',function(e){
console.log('data read error'+e)
})

stream的读写

//文件copy
var fs = require('fs') var readStream = fs.createReadStream('xpg.mp3') var writeStream = fs.createWriteStream('copy-xpg.mp3') readStream.on('data',function(chunk){
//数据还在缓冲区,未写完
if(writeStream.write(chunk) === false){
console.log('still cached')
//暂停读入,防止缓冲区爆掉
readStream.pause()
} }) readStream.on('end',function(){
writeStream.end()
}) //drain方法,数据被消费完,全部写入目标
writeStream.on('drain', function(){
console.log('data drain') //重新启动读操作
readStream.resume()
})

Stream种类

  • Readable 可读流,读取外部数据,将数据缓冲到内部的buffer数组
  • Writeable 可写流,消费buffer数组中的数据,写目标
  • Duplex 双工流
  • Transform 转换、双工

使用pipe

var http = require('http')
var fs = require('fs')
//需要安装 npm install request
var request = require('request') http
.createServer(function(req,res){
//通俗的做法
// fs.readFile('../buffer/logo.png', function(err,data){
// if(err){
// res.end('file not exist!')
// }else{
// res.writeHeader(200,{'Context-Type':'text/html'})
// res.end(data)
// }
// }) //简洁的方案
//fs.createReadStream('../buffer/logo.png').pipe(res) //爬取网络中的图片
request('http://img2.mukewang.com/szimg/5a67ebf50001b6d005400300-228-128.jpg')
.pipe(res) })
.listen(8090) console.log('run on 8090')

使用pipe重写stream的直接读写

var fs = require('fs')

fs.createReadStream('xpg.mp3').pipe(fs.createWriteStream('xpg-pipe.mp3'))

pipe连接Readable和Writabel


//文件copy
var fs = require('fs') var readStream = fs.createReadStream('xpg.mp3') var writeStream = fs.createWriteStream('copy-xpg.mp3') readStream.on('data',function(chunk){
//数据还在缓冲区,未写完
if(writeStream.write(chunk) === false){
console.log('still cached')
//暂停读入,防止缓冲区爆掉
readStream.pause()
} }) readStream.on('end',function(){
writeStream.end()
}) //drain方法,数据被消费完,全部写入目标
writeStream.on('drain', function(){
console.log('data drain') //重新启动读操作
readStream.resume()
})

自己定制的Readable Write

var stream = require('stream')
var util = require('util') //定制可读流
function ReadStream(){
stream.Readable.call(this)
}
//使ReadStream 继承stream.Readable的原型
util.inherits(ReadStream,stream.Readable) ReadStream.prototype._read = function(){
this.push('I')
this.push('Love')
this.push('You')
//null结束
this.push(null)
}
//===定制可写流
function WriteStream(){
stream.Writable.call(this)
this._cached = new Buffer('')
} util.inherits(WriteStream,stream.Writable) WriteStream.prototype._write = function(chunk, encode, cb){
console.log(chunk.toString())
cb()
} //定制转换流
function TransformStream(){
stream.Transform.call(this)
} util.inherits(TransformStream,stream.Transform) TransformStream.prototype._transform = function(chunk, encode, cb){
this.push(chunk)
cb()
} TransformStream.prototype._flush = function(cb){
this.push('OK')
cb()
} var rs = new ReadStream()
var ws = new WriteStream()
var ts = new TransformStream() rs.pipe(ts).pipe(ws)

11慕课网《进击Node.js基础(一)》Buffer和Stream的更多相关文章

  1. 01慕课网《进击Node.js基础(一)》Node.js安装,创建例子

    版本:偶数位为稳定版本,基数为非稳定版本 - 0.6.x - 0.7.x    - 0.8.x -0.9.x    -0.10.x  -0.11.x 概念:Node.js采用谷歌浏览器的V8引擎,用C ...

  2. 03慕课网《进击Node.js基础(一)》API-URL网址解析

    url url.parse(url,query,host);解析域名 url必须,地址字符串 query可选 host 可选:在不清楚协议时正确解析 querystring 字符串和对象之间互相解析 ...

  3. 10慕课网《进击Node.js基础(一)》初识promise

    首先用最简单的方式实现一个动画效果 <!doctype> <html> <head> <title>Promise animation</titl ...

  4. 07慕课网《进击Node.js基础(一)》HTTP小爬虫

    获取HTML页面 var http = require('http') var url='http://www.imooc.com/learn/348' http.get(url,function(r ...

  5. 进击Node.js基础(二)

    一.一个牛逼闪闪的知识点Promise npm install bluebird 二.Promise实例 ball.html <!doctype> <!DOCTYPE html> ...

  6. 02慕课网《进击Node.js基础(一)》——CommonJs标准

    是一套规范管理模块 每个js 为一个模块,多个模块作为一个包 node.js和Couchdb是对其的实现: 不同于jQuery 模块:定义.标识.引用(地址/模块名称) 模块类型: 核心模块http ...

  7. 进击Node.js基础(一)

    一.前言 1:Node.js本质上是用chrome浏览器 v8引擎 使用c++编写的JS运行环境 2:相比于JS没有浏览器安全级的限制,额外提供了一些系统级的API:文件读写,进程管理,网络通信等. ...

  8. 04慕课网《进击Node.js基础(一)》HTTP讲解

    HTTP:通信协议 流程概述: http客户端发起请求,创建端口默认8080 http服务器在端口监听客户端请求 http服务器向客户端返回状态和内容 稍微详细解析: 1.域名解析:浏览器搜素自身的D ...

  9. 09慕课网《进击Node.js基础(一)》HTTP-get/request

    get是对request封装 可以在后台发起http请求,获取远程资源,更新或者同步远程资源 http.request(options[,callback]) 以下代码灌水失败: var http = ...

随机推荐

  1. Redis系列三:reids常用命令

    全局命令 keys *  查看所有键 dbsize 查看的是当前所在redis数据库的键总数 如果存在大量键,线上禁止使用此指令 exists key 检查键是否存在,存在返回1,不存在返回0 del ...

  2. jenkins发版脚本更新

    jenkins 项目名中明确了 是jar tar.gz war包研发需要提供  项目名-地点-环境(研发.测试.生产)-应用项目名称(admin)-包格式(jar\war\gz) deployment ...

  3. 7、JVM--虚拟机类加载机制

    7.1.概述 再类文件结构中 在Class文件中描述的各种信息,最终都需要加载到虚拟机中之后才能运行和使用. 而虚拟机如何加载这些Class文件?Class文件中的信息进入到虚拟机后会发生什么变化? ...

  4. ActivityCapture

    Index: ActivityCapture.java =================================================================== --- ...

  5. Kubernetes1.91(K8s)安装部署过程(七)--coredns安装

    为了是集群内的服务能使用dns进行服务解析,集群内需要使用dns服务器,可以按照kube官方dns,即kubedns或者其他的dns,比如coredns, 本例中按照的为coredns,按照简单,编辑 ...

  6. 【转】SQL 常用关键字释义和用法

    转自: http://blog.csdn.net/iamwangch/article/details/8093933     下面 是 从网络上整理 出来的 SQL 关键字和 常用函数的 释义和简单用 ...

  7. Python2.7-filecmp

    filecmp 模块,定义了比较文件或目录的函数,比较文件只会有 True 和 False 两种结果,比较目录会返回目录下相同的文件,不同的文件,出错的文件.比较文件也可以用 difflib 模块,d ...

  8. JAVA框架 Spring 入门

    一.阐述: IoC:我们以前写的框架虽然我们已经进行分层,web.业务层.持久层.但是各个层之间的关系.耦合性比较高,那个层调用其他层的时候,需要new对应层的类的对象,这样的话,我们以后做修改的时候 ...

  9. CSS中的before和:after伪元素深入理解

    1.定义: “伪元素”,顾名思义.就是它创建了一个虚假的元素,并且将其虚假的元素插入到目标元素的内容之前或之后. 2:特点: a.它在实际文档中不改变什么,但是对用户可见,可以通过css控制,源码中看 ...

  10. Android 给TextView中的字体加上“中间线”

    大家都知道在做购物App或者购物网站的时候,商品价格往往会有一个“现价”和“原价”而原价往往会在中间加上一个黑色的横线.便于醒目客户,但是这种效果在App中应该怎样做呢? 废话不多少,直接给大家看代码 ...