Java中String和byte[]互转问题

最近使用tlv协议传输数据,发现Java中的String存放二进制数剧是有问题的。代码如下:

        byte[] bytes ={3,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,1,0,1,0,0,1,17,0,0,84,1,-128,97,97,97,97,97};    
        for(int i=0; i<40; ++i){
            System.out.print(bytes[i] + ",");
        }
        System.out.println();


        String str = new String(bytes, 0 , bytes.length, "UTF-8");  
        byte[] bytes_t = str.getBytes();//这个byte[]与之前的不相同       
        for(int i=0; i<40; ++i){
            System.out.print(bytes_t[i] + ",");
        }

输出结果为:
3,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,1,0,1,0,0,1,17,0,0,84,1,-128,97,97,97,97,97,
3,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,1,0,1,0,0,1,17,0,0,84,1,63,97,97,97,97,97,

可以看出用String构造函数生成的String,经过getBytes()函数后,得到的byte数组与之前的不一样。
所以当byte[]包含二进制数据时,不能用String构造函数将String转化为byte数组
(如果是字符串经过getBytes()后得到的byte[],这样互转是没有问题的)

正确的方法应该是把byte[]转化为16进制字符串;
然后再逆转化,就可以得到原来的byte[]。

byte[]和16进制字符串互转代码:

/**
     * byte[]转化为16进制字符串
     * @param src
     * @return
     */
    public static String bytesToHexString(byte[] src){  
        StringBuilder stringBuilder = new StringBuilder("");  
        if (src == null || src.length <= 0) {  
            return null;  
        }  
        for (int i = 0; i < src.length; i++) {  
            int v = src[i] & 0xFF;  
            String hv = Integer.toHexString(v);  
            if (hv.length() < 2) {  
                stringBuilder.append(0);  
            }  
            stringBuilder.append(hv);  
        }  
        return stringBuilder.toString();  
    }

    /**
     * 16进制字符串转化为byte[]
     * @param hexString
     * @return
     */
    public static byte[] hexStringToBytes(String hexString) {  
        if (hexString == null || hexString.equals("")) {  
            return null;  
        }  
        hexString = hexString.toUpperCase();  
        int length = hexString.length() / 2;  
        char[] hexChars = hexString.toCharArray();  
        byte[] d = new byte[length];  
        for (int i = 0; i < length; i++) {  
            int pos = i * 2;  
            d[i] = (byte) (charToByte(hexChars[pos]) << 4 | charToByte(hexChars[pos + 1]));
        }  
        return d;  
    }

    private static byte charToByte(char c) {
        return (byte) "0123456789ABCDEF".indexOf(c);
    }  

主函数调用:

String str_bin = bytesToHexString(bytes);
System.out.println(str_bin);

bytes = hexStringToBytes(str_bin);
for(int i=0; i<40; ++i){
    System.out.print(bytes[i] + ",");
}

输出:
03350000000000000000000000000000000000000000200100010000011100005401806161616161
3,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,32,1,0,1,0,0,1,17,0,0,84,1,-128,97,97,97,97,97,

可以看出互转之后byte[]是没有问题的。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值