今天遇到这样一个bug:客户端POST到服务器的一段数据导致服务器端发生未知异常。服务器端确认是编码转换错误。于是截取网络数据包进行分析,发现客户端POST的json数据中包含下面一段(hex形式):

... 61 64 20 b7 20 52 69 63 ...

问题就出在这个b7上。查阅Unicode代码表后发现,U+00b7是MIDDLE DOT,它的UTF-8表现形式应该是c2 b7,但为何客户端发送的数据中它变成了b7?

由于系统使用了ormlite、gson和async-http几个库,于是逐一排查。最后发现原来是向服务器发送数据时没有指定文字编码,导致async-http(实际是apache common http client)将数据以ISO-8559-1格式发送,U+00b7被编码成b7,然后服务器试图使用UTF-8解码时发生错误。

出错的代码片段如下:

Gson gson = new Gson();

String json = gson.toJson(data);

StringEntity entity = new StringEntity(json);

httpClient.post(context, url, entity, "application/json", new TextHttpResponseHandler() ... );

第三行new StringEntity(json)时没有指定编码导致错误。改正后如下:

Gson gson = new Gson();

String json = gson.toJson(data);

StringEntity entity = new StringEntity(json, "utf-8");

httpClient.post(context, url, entity, "application/json;charset=utf-8", new TextHttpResponseHandler() ... );

android mysql 乱码_android POST数据遇到的UTF-8编码(乱码)问题解决办法相关推荐

  1. mysql 导出过长的数字列时变科学计数法问题解决办法

    mysql 导出过长的数字列时变科学计数法问题解决办法 参考文章: (1)mysql 导出过长的数字列时变科学计数法问题解决办法 (2)https://www.cnblogs.com/yangjinw ...

  2. android mysql 记事本_android项目 之 记事本(11) ----- 加入数据库

    本文是自己学习所做笔记.欢迎转载.但请注明出处:http://blog.csdn.net/jesson20121020 通过之前的10节,已实现了记事本的大部分功能,有加入拍照.加入照片,加入录音,加 ...

  3. android mysql项目实例_android项目中单实例数据库类

    一.数据库操作 package com.ping.db; import android.content.Context; import android.database.sqlite.SQLiteDa ...

  4. android mysql 图片_android sqlite添加图片到数据库

    sqlite图片是怎么储存的呢?其实是二进制的方式存储的 blob代表使用二进制储存 (更多类型参考:数据库简介) 在创建表的地方,VALUE_PIC代表存储图片字段,blob代表这个字段是以二进制储 ...

  5. MySQL导入Excel报1406_关于mysql 导入excel 中 数据不全或导入不了的 处理办法(工具sqlyong)借鉴经验...

    文章作者:姜南(Slyar)文章来源:Slyar Home (www.slyar.com) 转载请注明,谢谢合作. 之前发了<表达式变量批量替换器 batchSQL>这篇文章,有童鞋说导入 ...

  6. mysql sys exec_mysql提权lib_mysqludf_sys执行sys_exec出现32256的问题解决办法

    使用lib_mysqludf_sys提权,执行select sys_exec返回数字32256问题的主要原因是所执行的shell脚本无权限,也就是mysql无法执行,将shell脚本放在mysql s ...

  7. Android之部分手机(oppo r9s)安装app出现崩溃问题解决办法

    1.问题现象 部分手机(oppo r9s)安装release版本的apk出现了崩溃,但是部分手机安装正常 2.崩溃日志 01-15 09:42:37.239 5889 5889 E AndroidRu ...

  8. 微信 android兼容性问题怎么解决方案,Android11 APP拉不起微信授权问题解决办法

    Android 11 加强了隐私保护策略,引入了大量变更和限制,其中一个重要变更 -- 软件包可见性 ,将会导致第三方应用通过微信OpenSDK的接口无法正常拉起微信,从而无法使用微信的全部功能,包括 ...

  9. android与mysql数据库同步_android开发 如何通过web服务器访问MYSQL数据库并且使其数据同步到android SQLite数据库?...

    通过web服务器访问MYSQL数据库有以下几个过程: 1.在MySql下创建自己的数据库和自己的表单 2.连接数据库. 3.访问数据库 1.创建web工程 (服务器端) 在Myeclipse下新建一个 ...

最新文章

  1. 相机自动对焦AF原理
  2. 【bzoj1853】[Scoi2010]幸运数字 容斥原理+搜索
  3. Ubuntu/Debian 系统切换Java(JVM),修改Java版本,JAVA_HOME
  4. kingcms php 下载,KingCMS _KingCMS官方网站
  5. 学完可以解决90%以上的数据分析问题-利用python进行数据分析第二版(代码和中文笔记)...
  6. python写界面c这算法_插入算法分别从C,java,python三种语言进行书写
  7. django用户认证系统——登录4
  8. 【Vegas原创】重建Exchange 2007 OWA的虚拟目录
  9. fullpage.js使用指南
  10. python turtle输出坐标_如何在Python/turtle中使用坐标列表绘制形状
  11. 景区门票分销系统解决方案
  12. GPRS-PDP上下文的激活过程
  13. 虚拟机一插U盘或读卡器就死机的解决办法
  14. Java SE(7)
  15. Content-Type 属性值
  16. WAF学习之一——Nginx与反向代理
  17. 局域网通信软件MTalk
  18. 掘金mysql_我的 mysql 半年小得 | 掘金征文
  19. 【verbs】ibv_create_comp_channel()
  20. wltp和nedc续航差多少_电动汽车续航里程测试中,NEDC、WLTP、EPA哪种最真实?

热门文章

  1. devops 三十六计_DevOps从业人员应遵循的16个博客和新闻通讯
  2. 实时录制视频,实时去除人_录制实时演示,第2部分:软件设置
  3. Jono Bacon的社区管理指南
  4. (23)npm项目发布
  5. ES6(ECMAScript2015)/01/ES6简介
  6. 实践 | Centos 7搭建LVS+Keepalived高可用Web服务群集群
  7. mysql 如何磁阵_Raid教程 全程图解手把手教你做RAID
  8. ajax多选下拉,模拟select下拉框之多选(数据源采用模拟Ajax数据--原创)(示例代码)...
  9. 看完这篇,你的老电脑能够快到起飞再也不卡!
  10. lasso模型交替方向matlab_TCGA系列学习笔记(7)建模及模型评价