解决PHP服务端返回json字符串有特殊字符的问题

原创 2015年07月08日 10:17:22

1. 问题描述

在调用PHP后台接口发现后台接口返回的json字符串Gson一直解析不通过:

List<Region> districts = null;
        if (!TextUtils.isEmpty(myString))
        {
            Gson gson = new Gson();
            try
            {
    districts = gson.fromJson(myString, new TypeToken<List<Region>>()
                {}.getType());
            }
            catch (Exception e)
            {
                e.printStackTrace();
            }
        }

异常提示的大概内容是:第一行第一列期望对象数组开头,实际却是字符串开头
以上myString 是个json字符串,内容如下:

这里写图片描述

2. 分析过程

(1) 将以上的json字符串复制到json在线检查,也是没通过
(2) json字符串保存在文件,在chrome浏览器打开此文件也没有显示json排版的格式;
(3) 仔细检查格式,没发现什么问题,根据异常提示的信息,很有可能是第一行第一列有特殊字符存在
(4) 仔细在EditPlus 编辑器查看上面的json字符串,发现 [ 很特别,不是正常的总括号
(5) 如果手动修改成正常的 [ , 复制到JSON在线检查里面,json合格,通过!
(6) 修改前的json字符串保存成一个文件,修改后的json字符串保存成一个文件
(7)为了进一步看出是这第一个什么字符,我改用了UltraEdit编辑器分别打开修改前的文件 和修改后的文件

这里写图片描述

这里写图片描述

然后分别 以16进制查看(编辑->16进制函数 -> 16进制编辑)

有特殊字符串的json字符串errorcode_region.txt 文件16进制查看内容如下:

这里写图片描述

没有特殊字符,修改后正常的json字符串 new_regions.txt 文件 16进制查看内容如下:

这里写图片描述

通过比较发现在正常的 [ 符号 多的特殊字符 16进制是 EF BB BF

通过 查看相关资料 它是 BOM (Byte Order Mark,字节序标记)的 UTF-8编码。就是说此json 字符串 是 带了 BOM的UTF-8 格式的。

以下是UTF-8 BOM的一些说明,参考 :UTF-8有BOM和无BOM的区别

UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8编码是EF BB BF。所以如果接收者收到以EF BB BF开头的字节流,就知道这是UTF-8编码了。

UTF- 8编码的文件中,BOM占三个字节。如果用记事本把一个文本文件另存为UTF-8编码方式的话,用UE打开这个文件,切换到十六进制编辑状态就可以看到开 头的FFFE了。这是个标识UTF-8编码文件的好办法,软件通过BOM来识别这个文件是否是UTF-8编码,很多软件还要求读入的文件必须带BOM。可 是,还是有很多软件不能识别BOM。

在Firefox早期的版本里,扩展是不能有BOM的,不过Firefox 1.5以后的版本已经开始支持BOM了。现在又发现,PHP也不支持BOM。PHP在设计时就没有考虑BOM的问题,也就是说他不会忽略UTF-8编码的文件开头BOM的那三个字符。

3. 解决办法

既然知道了问题原因:PHP后台返回的UTF-8格式的JSON字符串开头带了BOM,那解决办法就是 去掉 这个BOM。

怎样去掉呢? 不可能在客户端去掉,应该是在PHP后台根据接口名字,找到该接口对应的代码所在的PHP文件,将此PHP文件保存格式为UTF-8 无BOM 格式。

(1) 用EditPlus 另存为的时候,编码选择 UTF-8

这里写图片描述

如果选择的是 UTF-8 +BOM, 那就包含了 BOM

注: 用EditPlus 打开带BOM的文件的时候,会在底部显示 UF-8+
这里写图片描述

打开不带BOM的文件的时候,会在底部显示 UTF-8

这里写图片描述

(2) 用UltraEdit 另存为的时候,编码选择 UTF-8 无BOM

这里写图片描述

如果选择的是 UTF-8 , 那就包含了 BOM

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

json_decode在php中的一些无法解析的字符串

关于json_decode在php中的一些无法解析的字符串,包括以下几种常见类型。 一、Bug #42186 json_decode() won't work with \l 当字符串中含有\l的...

JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解

JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decod...
  • jumtre
  • jumtre
  • 2016-05-13 11:16
  • 2214

java格式化字符串,在指定位置插入指定字符串,兼容中英文以及特殊字符,例如:换行,用于解决生成pdf换行问题等问题

解决pdf换行问题,在指定位置插入指定字符串,兼容中英文以及特殊字符

jQuery在异步请求数据返回后,调用$("selector").html(data.content);之后因为一些特殊字符或者',"不能显示内容的问题解决办法

这个曾经困扰我了大半天。我出的状况是: 首先说明,我返回的data.content内容是一个页面的html代码。 1.数据能通过jquery中的ajax异步正常返回,alert(data.co...

解析JSON问题(一)包含特殊字符

使用JSON从后台向前台传输数据的时候,当数据本身含有一些特殊字符,会导致JSON数据的解析出错。 使用下面的方法对即将向前台输出的json字符串进行处理,可以解决键盘上能输入的所有...

特殊字符导致json字符串转换成json对象出错

在对数据库取出来的数据(特别是描述信息)里面含有特殊字符的话,使用JSON.parse将json字符串转换成json对象的时候会出错,主要是双引号,回车换行等影响明显,左尖括号和右尖括号也会导致显示问...

java用字符串拼接SQL语句的特殊字符转义问题

在实际的项目开发中,往往会根据用户在界面的文本框中输入的信息,去数据库中做模糊查询。如果使用的是原始的JDBC和SQL,往往需要对用户的输入进行转义,避免生成的sql语法错误,或者防止SQL注入。比如...

完美解决QQ空间背景音乐中不能输入如"="等特殊字符问题

我们在免费添加QQ空间背景音乐的时候,需要能在线试听的歌曲链接地址,由于QQ空间对歌曲的地址要求比较严格,有等号的歌曲地址是不能添加在空间的,当然一般的都是再换一首歌曲试听,能找到有用的链接更好,如果...
  • iloli
  • iloli
  • 2012-01-12 19:02
  • 937

关于附件上传文件名包含特殊字符引起无发下载附件的问题解决办法

(1)不容许用户上传包含特殊字符的文件 在上传文件的时候,加上必要的效验;这个比较简单,改动量小。 另外文件名包含特殊字符的文件,比较少,原因是无法从键盘输入特殊字符!
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)