![](/img/trans.png)
[英]Netty UnpooledHeapByteBuf, strange and unjustified IndexOutOfBoundsException
[英]Netty throws IndexOutOfBoundsException
我目前正在将Netty集成到将使用XML消息进行通信的服务器上。 这些XML消息实际上是已被序列化为XML消息的对象,这些对象随后通过TCP连接发送。 我可以发送和接收对象,但是在发送到服务器的第二条消息中却出现以下异常:
java.lang.IndexOutOfBoundsException: readerIndex(306) + length(613) exceeds writerIndex(614): UnpooledUnsafeDirectByteBuf(ridx: 306, widx: 614, cap: 1024)
at io.netty.buffer.AbstractByteBuf.checkReadableBytes(AbstractByteBuf.java:1161)
at io.netty.buffer.AbstractByteBuf.skipBytes(AbstractByteBuf.java:734)
at io.netty.buffer.WrappedByteBuf.skipBytes(WrappedByteBuf.java:540)
at io.netty.handler.codec.xml.XmlFrameDecoder.decode(XmlFrameDecoder.java:176)
at io.netty.handler.codec.ByteToMessageDecoder.callDecode(ByteToMessageDecoder.java:227)
我有以下代码初始化频道:
@Override
public void initChannel(SocketChannel ch) throws Exception {
LOGGER.info("Accepted connection from " + ch.remoteAddress().toString());
ClientConnection connection = new ClientConnection(ch);
ch.pipeline().addLast(new XmlFrameDecoder(6000), connection);
}
以及以下代码来处理我收到的消息:
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) {
LOGGER.info("Got data");
ByteBuf buf = (ByteBuf)msg;
try (ByteBufInputStream is = new ByteBufInputStream(buf)) {
Message message = MessageFactory.getInstance().deserialize(is);
// does stuff with message...
} catch (Throwable ex) {
LOGGER.log(Level.WARNING, ex.getMessage(), ex);
} finally {
ReferenceCountUtil.release(msg);
}
}
此代码用于发送消息:
public void sendMessage(Message msg) {
ByteBufAllocator alloc = PooledByteBufAllocator.DEFAULT;
ByteBuf buf = alloc.buffer(1024);
try (ByteBufOutputStream outputStream = new ByteBufOutputStream(buf)) {
String message = MessageFactory.getInstance().serialize(msg) + "\0";
outputStream.write(message.getBytes());
this.socketChannel.writeAndFlush(buf);
} catch (IOException ex) {
LOGGER.log(Level.INFO, ex.getMessage(), ex);
}
}
我正在使用java.beans.XMLDecoder和XMLEncoder进行XML对象的编码/解码。 由于我要发送的邮件大小为307,我认为在处理完邮件后应清除缓冲区,但是事实并非如此。 有人对我的问题有任何想法吗?
事实证明,问题是XMLEncoder在XML文档的末尾添加了一个\\ n,这在Netty开始读取XML消息时搞砸了。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.