php处理json需掌握编码(json_encode)、解码(json_decode)、中文不转义(json_unescaped_unicode)、特殊类型映射及合法性校验五类操作。

如果您在PHP中需要处理JSON格式的数据,则必须掌握编码与解码的基本操作。以下是实现JSON数据转换的多种方法:
一、使用json_encode()将PHP变量编码为JSON字符串
该函数用于将PHP数组或对象转换为标准JSON格式的字符串,适用于向前端传输数据或保存结构化内容。
1、定义一个关联数组,例如:$data = ['name' => '张三', 'age' => 25, 'city' => '北京'];
2、调用json_encode()函数进行编码:$json_str = json_encode($data);
立即学习“PHP免费学习笔记(深入)”;
3、检查编码是否成功,可使用json_last_error()判断:if (json_last_error() !== JSON_ERROR_NONE) { echo '编码失败'; }
二、使用json_decode()将JSON字符串解码为PHP变量
该函数用于将接收到的JSON字符串还原为PHP中的数组或对象,是接收API响应或解析配置文件的关键步骤。
1、准备一个合法JSON字符串,例如:$json_str = '{"name":"李四","score":92.5,"active":true}';
2、调用json_decode()并指定第二个参数为true以获取关联数组:$array = json_decode($json_str, true);
3、若需获取对象形式,省略第二个参数或设为false:$obj = json_decode($json_str);
4、验证解码结果是否为null(可能因格式错误导致失败):if ($array === null && json_last_error() !== JSON_ERROR_NONE) { echo '解码失败'; }
三、处理中文字符不被转义的问题
默认情况下,json_encode()会对中文字符进行Unicode转义(如\u4f60\u597d),影响可读性,需通过选项禁用该行为。
1、在json_encode()中添加JSON_UNESCAPED_UNICODE标志:$json_str = json_encode($data, JSON_UNESCAPED_UNICODE);
2、如需同时保持其他优化效果,可组合多个常量:$json_str = json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);
四、处理JSON解析中的特殊类型与空值
PHP在解码时对null、布尔值和数字的识别依赖于原始JSON内容,需注意类型一致性及空值映射规则。
1、JSON中的null会被解码为PHP的NULL值:$result = json_decode('{"status":null}'); // $result->status === NULL
2、布尔值true/false严格对应PHP的true/false:$result = json_decode('{"flag":true}'); // $result->flag === true
3、当JSON中存在数值型字符串(如"123")时,不会自动转为整型,仍为string类型:$result = json_decode('{"id":"123"}'); // $result->id是字符串而非整数
五、验证JSON字符串合法性而不执行解码
在不确定输入JSON是否有效时,可先校验其语法正确性,避免因非法JSON触发警告或中断流程。
1、使用json_decode()配合静默模式检测:$valid = json_decode($input, null, 512, JSON_THROW_ON_ERROR) !== null;
2、更轻量的方式是仅检查返回值是否为null且无错误:$decoded = json_decode($input); if ($decoded === null && json_last_error() !== JSON_ERROR_NONE) { /* 非法JSON */ }
3、注意:空字符串、空白符或null输入均会导致解码失败,应提前trim()并判断非空:if (trim($input) === '') { /* 输入为空 */ }










