事情是这样的,运行了大半年程序突然故障了。
调试发现是json_encode返回值是空的。
json_encode是php的内置函数,按理来说是可以正常工作,可是为什么现在返回异常了呢。
于是调用函数json_last_error()捕获最近一次json处理异常的代码。
<?php
$str = '大家好abc-才是0-,真的好';
$str = substr($str,0,24);
$arr = ['test'=>$str];
$json = json_encode($arr);
var_dump(json_last_error()); //获取异常代码编号
好家伙,我得到的异常代码是 5。
对照码
0 JSON_ERROR_NONE
1 JSON_ERROR_DEPTH
2 JSON_ERROR_STATE_MISMATCH
3 JSON_ERROR_CTRL_CHAR
4 JSON_ERROR_SYNTAX
5 JSON_ERROR_UTF8
6 JSON_ERROR_RECURSION
7 JSON_ERROR_INF_OR_NAN
8 JSON_ERROR_UNSUPPORTED_TYPE
于是对照代码得知是 encode过程中有UTF8异常的问题。
然后查询流程代码,在json_encode之前,有对$arr数组里面值的字符串进行长度截取。
使用了substr()进行对字符串截取。
排查到被截取的字符串存在中文编码,由于是substr(),它各种编码支持不是很友好。
使用mb_substr()可以设置截取的字符的编码。对各种编码支持良好。
例如mb_substr($arr,0,24,'UTF8');
下面补上了