最近在项目中遇到json_encode返回false,通过json_last_error()和json_last_error_msg()函数获取到的错误代码为5,错误信息为Malformed UTF-8 characters, possibly incorrectly encoded,参考代码:
//用户信息
$data = [
'age' => 18,
'name' => '高久峰'
];
//过长字段截取
$data['name'] = substr($data['name'], 0, 2);
//保存为Json
$en_char = json_encode($data);
if (!$en_char)
{
print_r('错误码:' . json_last_error() . PHP_EOL);
print_r('错误信息:' . json_last_error_msg());
}输出:
错误码:5 错误信息:Malformed UTF-8 characters, possibly incorrectly encoded
本来以为是编码问题,毕竟用户上传的是excel文件报错的,多次进行编码结果也不行,后来想到是不是substr导致中文字符串出现问题了,于是改为下面:
//过长字段截取 $data['name'] = mb_substr($data['name'], 0, 2, 'utf-8');
于是ok了。
<?php function go($str) { echo'I\'m '.$str; } $goto='go'; $goto('gaojiufeng'...
<?php //设置Cookies数组 setcookie('Datatype[a]', '1'); setcookie('Datatype[b]', '2'); set...
首先看看以下代码:代码1:<?php $a=0.1; $b=0.7; if($a+$b==0.8) { echo "1"; } else{ echo "2"; } ?>代码2:<?php &n...
应用场景:PHP模拟购买,商品数量大于0才能购买常见代码:<?php //连接数据库 $con=mysqli_connect("localhost","ihuohuo","927464cy","ihuohuo");...
如果想在windows中执行php,并且让php脚本在后台运行,可以用下面的cmd命令start /b php D:\wwwroot\default\demo1\run.php例如上面的命令意思后台运行run.php,如果想用php编写异步代码: ...
使用php函数array_multisort()即可实现和SQL一样的order by排序. 例如我们需要对会员表按照主键降序排列,年龄升序排列://会员表数据 $list = []; $list[] = ['mid' =>&n...