`
fantaxy025025
  • 浏览: 1329708 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

Java中_byte[]转String问题_字节数组和字符串互转问题

 
阅读更多

 Java中_byte[]转String问题_字节数组和字符串互转问题

 

这两天得给不知哪里的服务器接口传图片,但cpp的程序,接口图片参数不是buty的,而是string的。

这就坏了,string在java里面是有编码的,不是纯粹的raw数据。

经过调试,最终发现内部协议接口规则:图片等二进制接口,不能用string,string在java中有字符集的概念

 

完事只好协调人力重写接口。

 

另外,java中string转化为byte后,再转回来,byte居然变了。

这里也有人碰到这个问题:

 

     最近的项目中要使用到把byte[]类型转换成String字符串然后通过网络发送,但发现发现出去的字符串和获取的字符串虽然是一样的,但当用String的getBytes()的方法得到的byte[]跟原来的byte[]是不一样的。

看如下代码:

 

bytebytes[] = new byte[] { 50, 0, -1, 28, -24 };

String string = new String(bytes);

byte[] ret = string.getBytes();

查看ret的数据发现是50, 0, -17, -65, -67, 28, -17, -65, -67,发现数据并不是原来的数据。

而使用如下代码就可以得到原来的数据:

 

bytebytes[] = new byte[] { 50, 0, -1, 28, -24 };

 

 

StringisoString = new String(bytes, "ISO-8859-1");

byte[] isoret = isoString.getBytes("ISO-8859-1");

这是为什么呢?原因是第一种方法默认是用UTF-8编码来生成String的,用System.getProperty("sun.jnu.encoding")可以得到Android默认编码是UTF-8。UTF-8是可变长度的编码,原来的字节数组就被改变了。而ISO8859-1通常叫做Latin-1,Latin-1包括了书写所有西方欧洲语言不可缺少的附加字符,其中 0~127的字符与ASCII码相同,它是单字节的编码方式,这样第二种方式生成的String里的字节数组就跟原来的字节数组一样。在new String使用其他编码如GBK,GB2312的话一样也会导致字节数组发生变化,因此要想获取String里单字节数组,就应该使用iso-8859-1编码。

 

-

-

-

0

+

+

+

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics