OFMessageDecoder 继承了抽象类 FrameDecoder。FrameDecoder 会将接收到的ChannelBuffers 转换成有意义的 frame 对象,在基于流的传输过程中,通常会发生分片和重组的情况,所以就需要一个解码器,根据特定协议的约束,将收到的包理解为相应的,易于应用逻辑层处理的对象。
代码如下:
public
class
OFMessageDecoder
extends
FrameDecoder {
OFMessageFactory
factory
=
new
BasicFactory();
// 实现父类的抽象方法,最后一个参数 buffer:
// buffer the cumulative buffer of received packets so far.
// Note that the buffer might be empty, which means you
// should not make an assumption that the buffer contains
// at least one byte in your decoder implementation.
@Override
protected
Object decode(ChannelHandlerContext ctx, Channel channel,
ChannelBuffer buffer)
throws
Exception {
List<OFMessage> message =
factory
.parseMessage(buffer);
return
message;
}
}
这个decode抽象方法会被FrameDecoder的messageReceived方法所调用,FrameDecoder也是一个UpstreamHandler,当有数据到达的时候就会收集数据到ChannelBuffer中而后解码。
这里调用的是 BasicFactory 的 parseMessage 方法,一次处理一个of msg,然后添加到链表中,这里重要的条件就是 openflow header 的长度和消息类型,然后调用枚举类型中个体的newinstance()方法生成对应的OFMessage。
public
List< OFMessage> parseMessage(ChannelBuffer data)
throws
MessageParseException {
List<OFMessage> msglist =
new
ArrayList< OFMessage>();
OFMessage msg =
null
;
while
(data.readableBytes() >= OFMessage.MINIMUM_LENGTH) {
data.markReaderIndex();
msg =
this .parseMessageOne(data);
if
(msg ==
null
) {
data.resetReaderIndex();
break
;
}
else
{
msglist.add(msg);
}
}
if
(msglist.size() == 0) {
return
null
;
}
return
msglist;
}
这样就使得进入流水线的所有信息都是具体的 OFMessage 便于各个模块的处理。