0

0

PHP如何读取再修改JSON文件_PHP读写改JSON文件法【流程】

星夢妙者

星夢妙者

发布时间:2026-02-19 19:43:03

|

268人浏览过

|

来源于php中文网

原创

php读取修改json文件需三步:读取→解析→回写,关键避坑点为编码、空文件、权限及json格式错误;须用file_get_contents+json_decode安全读取,检查返回值与解析错误,修改后用json_encode配合json_unescaped_unicode等选项格式化输出,并通过临时文件原子写入确保数据安全。

php如何读取再修改json文件_php读写改json文件法【流程】

PHP 读取并修改 JSON 文件,核心就三步:读文件 → json_decode 解析 → 修改数组 → json_encode 回写 → 保存。但实际踩坑最多的是编码、空文件、权限和 JSON 格式错误这四类问题。

file_get_contents + json_decode 安全读取 JSON 文件

别直接 includerequire JSON 文件——它不是 PHP 代码。必须用文件读取函数配合解析:

  • file_get_contents 读取原始字符串,注意检查返回值是否为 false(文件不存在或无读取权限)
  • json_decode($json, true) 的第二个参数设为 true,确保返回关联数组而非对象,后续修改更直观
  • 解析失败时 json_last_error() 会返回非零值,常见如 JSON_ERROR_SYNTAX(格式错误)、JSON_ERROR_DEPTH(嵌套过深)
  • 空文件或只有空白字符会导致 json_decode 返回 null,需提前判断:
    if ($content === '' || trim($content) === '') { $data = []; }

修改数组后用 json_encode 生成合法 JSON 字符串

PHP 数组改完后不能直接写入,json_encode 的选项直接影响可读性和兼容性:

  • 中文字符默认被转成 \uXXXX,加 JSON_UNESCAPED_UNICODE 保持可读:
    json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT)
  • JSON_PRETTY_PRINT 增加缩进,方便人工查看,但会增大文件体积;生产环境可省略
  • 如果数组含资源、闭包或循环引用,json_encode 会静默失败并返回 false,务必检查返回值
  • 浮点数精度问题:PHP 默认可能截断小数位,如需保留,改用 number_format 预处理再存字符串字段

file_put_contents 原子化写入,避免写坏原文件

不要先 unlink 再写新文件——中断会导致数据丢失。推荐「写临时文件 → 原子重命名」:

塔猫ChatPPT
塔猫ChatPPT

塔猫官网提供AI一键生成 PPT的智能工具,帮助您快速制作出专业的PPT。塔猫ChatPPT让您的PPT制作更加简单高效。

下载

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

  • 生成临时文件名:$tempFile = $jsonFile . '.tmp_' . uniqid();
  • file_put_contents($tempFile, $jsonString) 写入,检查返回字节数是否匹配预期长度
  • 成功后用 rename($tempFile, $jsonFile) 替换原文件(Linux/macOS 下是原子操作)
  • Windows 下 rename 跨卷会失败,此时应先 unlink($jsonFile)rename,但需确保前一步写入已成功
  • 写入前确认目录可写:is_writable(dirname($jsonFile))

遇到 json_encode 返回空或 false 怎么快速定位

这不是“没报错就等于成功”,json_encode 失败只返回 false,没有异常抛出:

  • 先用 var_dump($data) 看结构,重点排查:NULL 值、resource 类型(如未关闭的 fopen 句柄)、NaNINF
  • 逐层简化数据:从顶层键开始注释掉子数组,缩小问题范围
  • json_last_error_msg() 获取最后错误描述(PHP ≥ 5.5),比查错误码更直接
  • 时间戳建议统一存为整数(time()),避免 DateTime 对象无法序列化

最常被忽略的是文件编码和 BOM:确保 JSON 文件是 UTF-8 无 BOM 格式,否则 json_decode 可能因开头不可见字符直接失败——用编辑器另存为「UTF-8(无 BOM)」最稳妥。

热门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

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

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

245

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

786

2024.03.01

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2023.12.20

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

481

2023.11.27

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

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

660

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号