Socket通信使用netty接收16进制数据并解析

博客介绍了使用Netty通过Socket进行通信时,客户端数据为16进制的处理方法。包括继承StringDecoder读取16进制数据,解析时注意大小端转换,跨平台需将大端转小端;16进制转10进制时,要考虑对方正负号影响,字节以FF开头可能需取反。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  通信方式是socket,使用netty技术进行连接,客户端的数据类型是16进制;需要注意的地方:

1:读取16进制,我继承的是StringDecoder,在decode读取数据

@Override
protected void decode(ChannelHandlerContext ctx, ByteBuf msg, List<Object> out) throws Exception {
    String HEXES = "0123456789ABCDEF";
    byte[] req = new byte[msg.readableBytes()];
    msg.readBytes(req);
    final StringBuilder hex = new StringBuilder(2 * req.length);

    for (int i = 0; i < req.length; i++) {
        byte b = req[i];
        hex.append(HEXES.charAt((b & 0xF0) >> 4))
                .append(HEXES.charAt((b & 0x0F)));
    }
    out.add(hex.toString());

}

2:在解析16进制数据的时候注意大小端问题,socket是对TCP/IP协议的封装,TCP/IP协议规定了在网络上必须采用网络字节顺序,也就是大端模式;而windows和linux是使用的小端模式,所以在读取的时候需要转化为小端模式读取,一个字节没问题,但是多个字节时需要转换;后面的字节放前面,倒序排放;同个网络和平台可能没关系,例如java虚拟机内部已经进行了处理,但是跨平台的话需要注意;

如:String msg = "00 BC 45";要先变成String str = "45 BC 00";

3:如果是16进制转10进制,需要考虑对方正负号的影响,如果是字节以FF开头,一定要注意是否要取反。不需要的话就没关系,需要的话就记得转换

if (sixteen.startsWith("FF")){
    Long max = Long.parseLong("FFFFFFFF", 16);
    Long curLong = Long.parseLong(sixteen, 16);
    pos[i] = new Long(curLong - max).intValue();
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值