zoukankan      html  css  js  c++  java
  • HttpUrlConnection流传输问题(正确传输包含中文的JSON字符串)

    目前在写一个功能,主要是使用 HttpURLConnection 发送http请求调用外部接口。本来一切正常的,可是在发送post请求上传数据给服务端时,服务端返回错误信息:获取的JSON请求是乱码的。

    因为请求的 JSON 里面包含了中文,所以一开始我把思路锁定在了编码问题,这样就走进了死胡同。在把tomcat、JDK、请求头的 header 中的 Content-Type 全都排查了一遍后,确认都是utf-8编码呀,

    为什么还会出现乱码?熟练地打开了百度,但是一眼望去都是各种教你改 http 请求头的,或者如下:

    DataOutputStream out = null;
    out = new DataOutputStream(connection.getOutputStream());
    //out.writeBytes(content);
    out.write(content.getBytes());
    

    把 out.writeBytes(content) 换成 out.write(content.getBytes()) ,因为 java 里的 char 类型是16位(2个字节)的,一个 char 可以存储一个中文字符,在将其转换为 byte(1个字节)后高8位会丢失,这样就无法将中文字符串完整的输出到字节输出流中。所以在可能有中文字符输出的地方最好先将字符串转换为字节数组,然后再通过 write() 写入字节输出流。

    但是,这种方法只对有的人的问题生效,没有解决我的问题。直到我看到了这篇博客 https://blog.csdn.net/hwj3747/article/details/53635539

    PrintWriter out = null;
    out = new PrintWriter(new OutputStreamWriter(connection.getOutputStream(),"utf-8")); 
    out.println(content);
    

    思路是用字符流代替字节流进行传输,因为我们传入的JSON字符串是纯字符。这样就完美避开了用字节流传输包含中文的字符串可能存在的各种转化问题。

    总结:因为长期在写业务代码,所以对Java底层流机制非常生疏了。

  • 相关阅读:
    python excel导入到数据库
    ubuntu14.04修改mysql默认编码
    python 向MySQL里插入中文数据
    hbase框架原理
    hive框架原理
    Hadoop的MapReduce模型基本原理
    机器学习模型效果评价
    spark架构原理
    Hadoop架构原理
    特征工程
  • 原文地址:https://www.cnblogs.com/zhangjianghao/p/9453731.html
Copyright © 2011-2022 走看看