0

0

PHP 数组与 JSON 转换的面试考点

舞姬之光

舞姬之光

发布时间:2026-03-02 20:10:45

|

123人浏览过

|

来源于php中文网

原创

php数组与json转换需关注编码安全、类型处理及错误校验:中文须utf-8编码并加json_unescaped_unicode;浮点数精度需格式化或用json_preserve_zero_fraction;json_decode()务必检查返回值与错误码。

php 数组与 json 转换的面试考点

PHP 中数组与 JSON 的转换看似简单,但面试官常通过细节考察你对数据类型、编码安全、边界情况的理解深度。核心不是会不会用 json_encode()json_decode(),而是能否写出健壮、可维护、符合实际场景的代码。

数组转 JSON:别只盯着 json_encode(),重点看参数和陷阱

基础用法谁都懂,但高频考点在于:

  • 中文乱码? 确保源数组中的字符串是 UTF-8 编码。非 UTF-8(如 GBK)需先转换:mb_convert_encoding($arr, 'UTF-8', 'GBK'),否则 json_encode() 会返回 false 或空字符串。
  • 中文被转成 Unicode? 加上 JSON_UNESCAPED_UNICODE 选项:json_encode($arr, JSON_UNESCAPED_UNICODE),避免 "\u4f60\u597d" 这类可读性差的输出。
  • 浮点数精度丢失? PHP 默认将 float 转为 15 位有效数字。若需更高精度(如金融场景),应提前格式化为字符串再存入数组,或使用 JSON_PRESERVE_ZERO_FRACTION(PHP 7.1+)配合科学计数法控制。
  • 对象/资源/闭包怎么处理? json_encode() 会静默跳过资源和不可序列化对象,对普通对象默认只编码 public 属性。若需自定义,应实现 JsonSerializable 接口。

JSON 转数组:json_decode() 的第二个参数不是可有可无

是否传 true 决定返回关联数组还是对象,这直接影响后续代码逻辑:

遨虾
遨虾

1688推出的跨境电商AI智能体

下载
  • true → 返回 array,可用 $data['name'] 访问,适合配置、API 响应等结构明确的数据。
  • 不传或传 false → 返回 stdClass 对象,必须用 $data->name,适合快速映射 JSON 结构且不打算修改的情况。
  • 务必检查返回值! JSON 格式错误、超深嵌套、超大数值(如超出 PHP_INT_MAX)都会导致返回 null。正确做法是结合 json_last_error() 判断:
    $data = json_decode($json, true);<br>if ($data === null && json_last_error() !== JSON_ERROR_NONE) {<br>  throw new InvalidArgumentException('Invalid JSON: ' . json_last_error_msg());<br>}

常见组合场景与避坑指南

真实项目中往往不是单步操作,而是链路协作:

立即学习PHP免费学习笔记(深入)”;

  • 从数据库查出数据 → 转 JSON → 前端渲染:注意 MySQL 的 datetime 字段在 PHP 中是字符串,但若用了 PDO::ATTR_EMULATE_PREPARES = false,可能返回 DateTime 对象——它不能被直接 JSON 编码,需提前 format() 或统一 cast 为字符串。
  • 接收前端 POST 的 JSON → 解码 → 验证 → 存库:不要直接 json_decode(file_get_contents('php://input')) 就完事。要校验 Content-Type 是否为 application/json,限制输入长度防 DOS,用 filter_var() 或专用验证器清洗字段(如防止注入 HTML/JS)。
  • 多维数组含循环引用? json_encode() 会报错(JSON_ERROR_RECURSION)。需提前用 serialize() + unserialize() 或自定义递归检测函数剥离引用。

扩展考点:性能与替代方案

高频调用场景下,基础函数可能不够用:

  • 大量小 JSON 拼接? 避免反复 json_encode() + 字符串拼接,改用 json_encode() 一次编码整个结构体更高效。
  • 需要流式解析超大 JSON? json_decode() 会全量加载到内存。此时应考虑 json streaming parser 类库(如 ralouphie/json-streaming-parser),边读边处理。
  • 兼容旧版本 PHP? PHP 5.2+ 支持基本 JSON 函数,但 JSON_INVALID_UTF8_IGNORE(PHP 7.2+)等新选项需做版本判断或降级处理。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

682

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

452

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

264

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

541

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

663

2023.08.14

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号