使用的netty 框架解析
所遇到的问题:
一:发送过来的message 消息有大小端的问题
二:拆包和粘包的问题
解决方式:
一:大小端解决
/** * 将int转为低字节在前,高字节在后的byte数组 * @param n int * @return byte[] */ public static byte[] toLH(int n) { byte[] b = new byte[4]; b[0] = (byte) (n & 0xff); b[1] = (byte) (n >> 8 & 0xff); b[2] = (byte) (n >> 16 & 0xff); b[3] = (byte) (n >> 24 & 0xff); return b; } /** * 将int转为高字节在前,低字节在后的byte数组 * @param n int * @return byte[] */ public static byte[] toHH(int n) { byte[] b = new byte[4]; b[3] = (byte) (n & 0xff); b[2] = (byte) (n >> 8 & 0xff); b[1] = (byte) (n >> 16 & 0xff); b[0] = (byte) (n >> 24 & 0xff); return b; } /** * 将short转为低字节在前,高字节在后的byte数组 * @param n short * @return byte[] */ public static byte[] toLH(short n) { byte[] b = new byte[2]; b[0] = (byte) (n & 0xff); b[1] = (byte) (n >> 8 & 0xff); return b; } /** * 将short转为高字节在前,低字节在后的byte数组 * @param n short * @return byte[] */ public static byte[] toHH(short n) { byte[] b = new byte[2]; b[1] = (byte) (n & 0xff); b[0] = (byte) (n >> 8 & 0xff); return b; }
二:拆包和粘包的问题解决方式
我这里是通过,包头中带长度来算,一个包的的结束
这里有两种情况
1:发过来 byteBuf 的writerIndex长度大于 包头的长度这说明bytebuf有可能有一个以上的消息包这里需要拆包
这里根据包头中带的包长,把一个完整包读完,然后用byteBuf的discardReadBytes() 这个方法删除掉已读的长度同时重置读取位置。这个时候byteBuf 里面还有半个以上的包,这里一样从包头里面取出包长和byteBuf的writerIndex作比较,如果是半个包就重置读取位置,然后return,等下一个消息把包给拼全,然后正常读取,然后删除已读的。
2c++那边发了一个消息,到java 这边却收到了两个消息,这个就需要粘包,粘包比较简单
同样判断包头长度和消息的总长度 然后发过来的第一个消息的总长度小于包头长度,这说明是半个包,然后重置读取坐标,return,下个消息会补全这个消息包,当包头长度等于总长度,就正常读取一个消息包。