netty中LengthFieldBasedFrameDecoder的使用

转载 2015年07月11日 09:56:34

在org.jboss.netty.handler.codec.frame包中,有LengthFieldBasedFrameDecoder类用来解析带有长度属性的包,只要我们在传输协议中加入包的总长度就行了(也许有更好的方法)

 

具体方法:

1.可在数据包前加4个字节表示包的总长度,例如:

 

/** 
* 传输协议
* |------------------------------------------
* |总长度4byte |pkey长度4byte      |
* |------------------------------------------
* | value 4byte|name 4byte|zip  1 |
* |------------------------------------------
* |skey值      8byte(long型时间,固定) |
* |------------------------------------------------
* |  包体内容                                             |
* |                    
* |------------------------------------------------

在通过netty传输数据之前,执行

 

2.在接受的ChannelPipeline中加入decoder,加在handler之前,例如:

 

 

  1. bootstrap.setPipelineFactory(new ChannelPipelineFactory() {  
  2.            public ChannelPipeline getPipeline() throws Exception {  
  3.             ChannelPipeline pipeline = new DefaultChannelPipeline();  
  4.             pipeline.addFirst("decoder", new LengthFieldBasedFrameDecoder(100000000,0,4,0,4));  
  5.             pipeline.addLast("handler", new XXX(config));  
  6.             return pipeline;  
  7.            }  
  8.        });  

 

 

使用LengthFieldBasedFrameDecoder作为decoder实现,LengthFieldBasedFrameDecoder构造函数,第一个参数为信息最大长度,超过这个长度回报异常,第二参数为长度属性的起始(偏移)位,我们的协议中长度是0到第3个字节,所以这里写0,第三个参数为“长度属性”的长度,我们是4个字节,所以写4,第四个参数为长度调节值,在总长被定义为包含包头长度时,修正信息长度,第五个参数为跳过的字节数,根据需要我们跳过前4个字节,以便接收端直接接受到不含“长度属性”的内容。

 

至此,接收端会按照decoder指定的长度接收完整后才会调用handler继续处理信息。

Netty权威指南 第2版学习笔记7——MessagePack编解码及LengthFieldBasedFrameDecoder

MessagePack是一个高效的二进制序列化框架,像JSON一样支持不同语言间的数据交换,速度更快,序列化之后的码流更小MessagePack特点 编解码高效,性能高 序列化后的码流小 支持跨语言 ...
  • xundh
  • xundh
  • 2017年01月02日 21:55
  • 2063

netty处理粘包问题——1

我们知道通过TCP协议发送接收数据时,如果数据过大,接收到的数据会是分包的,比如:                                     +-----+-----+-----+  ...
  • bestone0213
  • bestone0213
  • 2015年07月28日 17:20
  • 1422

netty 粘包问题处理

一般TCP粘包/拆包解决办法 定长消息,例如每个报文长度固定,不够补空格使用回车换行符分割,在包尾加上分割符,例如Ftp协议消息分割,头为长度(消息总长度或消息体长度),通常头用一个int32表...
  • AlbertFly
  • AlbertFly
  • 2016年07月27日 18:13
  • 862

Netty系列之Netty编解码框架分析

1. 背景 1.1. 编解码技术 通常我们也习惯将编码(Encode)称为序列化(serialization),它将对象序列化为字节数组,用于网络传输、数据持久化或者其它用途。 反之...
  • oufua
  • oufua
  • 2016年01月13日 21:27
  • 772

Mina、Netty、Twisted一起学(五):整合protobuf

protobuf是谷歌的Protocol Buffers的简称,用于结构化数据和字节码之间互相转换(序列化、反序列化),一般应用于网络传输,可支持多种编程语言。protobuf如何使用这里不再介绍,本...
  • xiao__gui
  • xiao__gui
  • 2014年08月27日 09:25
  • 5355

【看完就会】Netty的LengthFieldBasedFrameDecoder的用法详解

前言 LengthFieldBasedFrameDecoder类是Netty提供的用来解析带长度字段数据包的类,继承自ByteToMessageDecoder类。 一,粘包与拆包问题 经典的粘包...
  • zougen
  • zougen
  • 2018年01月11日 19:23
  • 19

Netty——基本使用介绍

1.为什么选择Netty 上一篇文章我们已经了解了Socket通信(IO/NIO/AIO)编程,对于通信模型已经有了一个基本的认识。其实上一篇文章中,我们学习的仅仅是一个模型,如果想把这些真正的用于实...
  • haoyuyang
  • haoyuyang
  • 2016年11月20日 19:51
  • 20896

你的第一个Netty应用

本章包括 获取Netty的最新版本 搭建环境来构建和运行例子 创建Netty的客户端和服务器端 拦截和处理错误 运行Netty客户端和服务器端 本章给出Netty核心概念的简单介绍,为本书后面的...
  • sn_gis
  • sn_gis
  • 2015年10月15日 06:51
  • 1239

protobuf在netty里面的应用举例

netty为protobuf提供了两个编码器(ProtobufEncoder,ProtobufVarint32LengthFieldPrepender),两个解码器(ProtobufVarint32F...
  • xuechongyang
  • xuechongyang
  • 2013年03月11日 15:55
  • 12865

Java NIO框架Netty简单使用

之前写了一篇文章:Java 网络IO编程总结(BIO、NIO、AIO均含完整实例代码),介绍了如何使用Java原生IO支持进行网络编程,本文介绍一种更为简单的方式,即Java NIO框架。 N...
  • anxpp
  • anxpp
  • 2016年08月03日 22:37
  • 6720
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:netty中LengthFieldBasedFrameDecoder的使用
举报原因:
原因补充:

(最多只允许输入30个字)