分享NodeJs中TCP粘包、分包解决方案
发布于 8 年前 作者 lvgithub 14088 次浏览 最后一次编辑是 7 年前 来自 分享

StickPackage,NodeJs中TCP粘包、分包解决方案!

持续更新,源码地址,喜欢的话请点star,想订阅点watch 配置介绍

  • [x] 提供对TCP粘包处理的解决方案
  • [x] 默认缓冲512个字节,当接收数据超过512字节,自动以512倍数扩大缓冲空间
  • [x] 本默认采用包头两个字节表示包长度
  • [x] 默认采用大端接模式接收数据
  • [x] 可以配置大端小端读取
  • [x] 可以配置自定义包头长度

Changes:

  • 设置大端,小端接收,添加setReadIntBE,添加setReadIntLE方法:
setReadIntBE(type) ,setReadIntLE(type)  type:16  包头长度为2,short类型
setReadIntBE(type) ,setReadIntLE(type)  type:32  包头长度为4,int类型

使用方法(进入项目有test函数进行演练)

var Stick = require('./index');
let stick = new Stick(1024).setReadIntBE('16')

/*
*  包含两个数据包,10个字节,包头为short,两个字节:[0x00, 0x02],[ 0x00, 0x04]
*  数据包1:[0x00, 0x02, 0x66, 0x66]
*  数据包2:[0x00, 0x04, 0x88, 0x02, 0x11, 0x11]
*/
let data = Buffer.from([0x00, 0x02, 0x66, 0x66, 0x00, 0x04, 0x88, 0x02, 0x11, 0x11]);

/*  构造两个buffer
*   data2_1包含:  第一个数据包的全部数据,第二个数据包的部分数据	
*   data2_2包含:  第二个数据包的剩余数据
*/
let data2_1 = Buffer.from([0x00, 0x00, 0x00, 0x02, 0x66, 0x66, 0x00, 0x04, 0x88, 0x02, 0x11]);
let data2_2 = Buffer.from([0x11]);

// 设置收到完整数据触发器
stick.onData(function (data) {
    console.log('receive data,length:' + data.length);
    console.log(data)
});

stick.putData(data);        
stick.putData(data2_1);
stick.putData(data2_2);  

 运行结果:   
//  receive data,length:4 <Buffer 00 02 66 66>  
//  receive data,length:6 <Buffer 00 04 88 02 11 11>
//  receive data,length:2< Buffer 00 00> receive data, length:4 < Buffer 00 02 66 66> receive data, length:6< Buffer 00 04 88 02 11 11>

源码地址,喜欢的话请点star,想订阅点watch


测试结果 2017-03-11 09-44-18 的屏幕截图.png 源码地址 喜欢的话请点star,想订阅点watch

11 回复

mark,刚好用到。

《nodejs 适合开发TCP服务吗?》 https://cnodejs.org/topic/58bfb544d4f292914a6d004b

来自酷炫的 CNodeMD

@joliuwei

来自酷炫的 CNodeMD

tcp 可不可以直接上 zmq?

来自酷炫的 CNodeMD

mark

来自酷炫的 CNodeMD

Changes:

  • 设置大端,小端接收,
  • 添加setReadIntBE(type)
  • 添加setReadIntLE(type)
     setReadIntBE(type) ,setReadIntLE(type) 
     * type:16  包头长度为2,short类型
     setReadIntBE(32) ,setReadIntLE(32)
     * type:32  包头长度为4,int类型
	 ```

先写一个解包的,然后才能处理黏包 黏包主要是 消息在网络缓存器内,比如长度为120个字节,获得tcp包头加tcp数据包长度 比如小于120字节,就依次切割。 黏包就是处理这部分的。

回到顶部