0

0

PHP JSON解析与生成教学_PHP处理JSON数据完整流程

舞夢輝影

舞夢輝影

发布时间:2025-12-18 22:25:32

|

959人浏览过

|

来源于php中文网

原创

php处理json的核心是json_encode()和json_decode():前者将php变量转json字符串,注意数组类型、中文编码及不可序列化值返回false;后者将json转php变量,默认返对象,加true参数返数组,失败返回null,需用json_last_error()或json_throw_on_error检查错误。

php json解析与生成教学_php处理json数据完整流程

PHP 处理 JSON 数据的核心就是 json_encode()json_decode() 两个函数,用对了就很简单,用错了就容易出 Warning 或返回 null。关键不在语法多难,而在理解数据类型转换规则和错误处理习惯。

JSON 生成:把 PHP 变量转成 JSON 字符串

json_encode() 把数组或对象转为合法 JSON 字符串。注意三点:

  • 关联数组(键名是字符串)会生成 JSON 对象 {"name":"张三"};索引数组(键名是数字且连续)会生成 JSON 数组 ["a","b"]
  • 中文默认被转成 Unicode(如 \u4f60),加 JSON_UNESCAPED_UNICODE 参数可保留原文:json_encode($data, JSON_UNESCAPED_UNICODE)
  • 如果变量含资源、闭包或不可序列化的对象,json_encode 会返回 false,建议加判断:if (false === $json = json_encode($data)) { /* 处理错误 */ }

JSON 解析:把 JSON 字符串转回 PHP 变量

json_decode() 还原数据,默认返回 stdClass 对象;传第二个参数 true 才返回关联数组:

  • json_decode('{"name":"李四"}') → 对象,取值写法:$obj->name
  • json_decode('{"name":"李四"}', true) → 数组,取值写法:$arr['name']
  • 解析失败时返回 null(不是 false!),可用 json_last_error() 查具体错误,比如 JSON_ERROR_SYNTAX 表示 JSON 格式不对
  • 常见坑:前端传来的 JSON 字符串可能带 BOM 或多余空格,建议先 trim($json_str) 再解析

实战中必须加的防护动作

真实项目里不能假设 JSON 一定合法。每次 decode 后都该检查:

PDFlux
PDFlux

PDF内容提取+智能问答神器,结合了科研级精准的非结构化文档解析能力,以及ChatGPT的智能问答能力。

下载

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

  • 是否为 null(解析失败)
  • 是否为期望类型(比如预期是数组,结果却是对象)
  • 关键字段是否存在(用 isset()array_key_exists()

一个轻量级校验示例:

$data = json_decode($input, true); if (null === $data || !is_array($data) || !isset($data['id'])) {   die('非法 JSON 或缺少 id 字段'); }

进阶技巧:自定义 JSON 行为

PHP 7.3+ 支持 JSON_THROW_ON_ERROR,让解析失败直接抛异常,比查错误码更直观:

  • json_decode($str, true, 512, JSON_THROW_ON_ERROR) —— 错误时抛 JsonException
  • 配合 try/catch 写法更干净,适合 API 接口层统一错误处理
  • 若需控制浮点数精度、跳过 NaN/INF,可用 JSON_PRESERVE_ZERO_FRACTION 等扩展标志

基本上就这些。不复杂但容易忽略细节,尤其是错误判断和中文编码。写完 encode/decode 多看一眼返回值,比事后 debug 快十倍。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

442

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

322

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

311

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

223

2025.10.31

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

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

精品课程

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

共137课时 | 12.1万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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