zoukankan      html  css  js  c++  java
  • java中string与byte[]的转换

    1.string 转 byte[]

    byte[] midbytes=isoString.getBytes("UTF8");
    //为UTF8编码
    byte[] isoret = srt2.getBytes("ISO-8859-1");
    //为ISO-8859-1编码
    其中ISO-8859-1为单字节的编码
    2.byte[]转string
    String isoString = new String(bytes,"ISO-8859-1");
    String srt2=new String(midbytes,"UTF-8");
     
    说明:
    在网络传输或其它应用中常常有同一的中间件,假设为String类型。因此需要把其它类型的数据转换为中间件的类型。
    将字符串进行网络传输时,如socket,需要将其在转换为byte[]类型。这中间如果采用用不同的编码可能会出现未成预料的问题,如乱码。
    下面举个例子:
    我们用socket传输String类型的数据时,常常用UTF-8进行编码,这样比较可以避免一个“中文乱码”的问题。
    发送端:
    String sendString="发送数据";
    byte[] sendBytes= sendString .getBytes("UTF8");
    .......socket发送
    接受端:
    String recString=new String( sendBytes ,"UTF-8");
     
    但是,这里往往又会出现这样一个问题。就是想要发送的数据本身就是byte[]类型的。
    如果将其通过UTF-8编码转换为中间件String类型就会出现问题
    如:
    byte[] bytes = new byte[] { 50, 0, -1, 28, -24 };
    String sendString=new String(  bytes ,"UTF-8");
    byte[] sendBytes= sendString .getBytes("UTF8");
    然后再发送
    接受时进行逆向转换
    String recString=new String( sendBytes ,"UTF-8");
    byte[] Mybytes=isoString.getBytes("UTF8");
    这时Mybytes中的数据将是[50, 0, -17, -65, -67, 28, -17, -65, -67]
     
    因此,需要采用单字节的编码方式进行转换
    String sendString=new String(  bytes ,"UTF-8");   改为       String sendString=new String(  bytes ,"ISO-8859-1" );
    byte[] Mybytes=isoString.getBytes("UTF8");  改为   byte[] Mybytes=isoString.getBytes(  "ISO-8859-1" );
    这样所需要的字节就有恢复了。
  • 相关阅读:
    FTP登录 下载上传文件(太过简单暂时未写)
    依据文档批次命名图片
    UDP协议
    tcp协议(三次握手 四次挥手)
    1956年人工智能元年,而今天是我进入人工智能的日子,哈哈哈
    对比文件简易代码
    爬取网站内容,存放到excel中
    Redis-Py 使用
    python list减法
    sort 使用key函数时,赋多个排序参数
  • 原文地址:https://www.cnblogs.com/exmyth/p/3412739.html
Copyright © 2011-2022 走看看