无法解析json,去除诡异的bom头(\ufeff)

无法解析json,去除诡异的bom头(\ufeff)

一.前言

项目中遇到了相同代码,不同环境下(预发布、正式服)无法解析接口返回的json字符,发现字符中带了"\ufeff"。

使用var_dump()打印出来,会比正常的字符串多3个字节,导致无法解析,其实urlencode和urldecode 之后 就可以看到 \ufeff了

$url = "http://******/OtherApi/**";
$result = file_get_contents($url);
var_dump(json_decode($result,true));  
echo '<br>';
var_dump($result);
exit;
无法解析例子,多出3个字节\ufeff:

浏览器打印:
浏览器打印
json解析工具(http://www.bejson.com/):
json解析工具

正常例子:

浏览器打印:
浏览器打印json解析工具(http://www.bejson.com/):
json解析工具

二.原因

用windows的记事本修改代码,是文本保存时包含了BOM(Byte Order Mark,字节顺序标记,出现在文本文件头部,Unicode编码标准中用于标识文件是采用哪种格式的编码)导致的。

排查:

可以使用NodePad++编辑器,查看编码格式,注意排查接口文件(api.php),甚至配置文件(config.php)、入口文件(index.php)的编码格式都要排查,如果出现UFT-8格式编码, 包含了BOM,可以使用NodePad++编辑器转换为无BOM格式的文件。
在这里插入图片描述

三.解决

1.方法1(推荐)修改文件格式为:无BOM编码格式

将源文件用NodePad++编辑器打开,修改为以UTF-8无BOM编码格式,然后另存为一个文件,替换原有文件。
注意使用php的TP框架线上模式的话,记得清下缓存文件。

1.转换格式,为无BOM编码
2.另存为
3.保存替换文件

2.方法2(治标不治本)用代码把特殊字符去掉
$url = "http://******/OtherApi/**";
$result = file_get_contents($url);
var_dump(json_decode($result,true)); 
echo '<br>';
$result = str_replace('\ufeff','',urldecode(urlencode($result))); //替换过滤字符
var_dump($result);
exit;
3.方法3(治标不治本)强制转换编码格式
$url = "http://******/OtherApi/**";
$result = file_get_contents($url);
var_dump(json_decode($result,true)); 
echo '<br>';
$result = iconv("utf-8","gbk//IGNORE",$result); //强制转换编码格式
var_dump($result);
exit;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值