信息发布→ 登录 注册 退出

php怎么数组组成json字符串_php数组转json字符串json_encode格式化法【教程】

发布时间:2025-12-09

点击量:
PHP中将数组转JSON需用json_encode():基础用法直接编码;加JSON_UNESCAPED_UNICODE可避免中文转义;加JSON_PRETTY_PRINT可格式化输出;非UTF-8编码需先转码;含资源等不可序列化数据须预处理。

如果您有一个 PHP 数组,需要将其转换为标准的 JSON 字符串格式,则可以使用内置函数 json_encode() 实现。以下是多种实现方式及对应细节说明:

一、基础 json_encode 转换

该方法适用于简单索引数组或关联数组,直接调用函数即可生成紧凑格式的 JSON 字符串。

1、定义一个 PHP 关联数组,例如:$data = ['name' => '张三', 'age' => 25, 'city' => '北京'];

2、调用 json_encode($data) 函数进行编码。

3、输出结果为:{"name":"\u5f20\u4e09","age":25,"city":"\u5317\u4eac"}(中文默认 UTF-8 编码,显示为 Unicode)。

二、中文不转义的 json_encode 处理

默认情况下,json_encode() 会对中文字符进行 Unicode 转义,若需保留原始中文字符,需添加特定常量参数。

1、在 json_encode() 第二个参数中传入 JSON_UNESCAPED_UNICODE 常量。

2、完整写法示例:json_encode($data, JSON_UNESCAPED_UNICODE)

3、输出结果为:{"name":"张三","age":25,"city":"北京"}

三、格式化缩进输出(美化 JSON)

为便于调试或阅读,可启用缩进与换行,使生成的 JSON 字符串具备可读性结构。

1、在 json_encode() 的第二个参数中加入 JSON_PRETTY_PRINT 常量。

2、若同时需中文不转义,组合使用两个常量:JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT

3、示例调用:json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT)

4、输出结果为多行缩进格式,含换行与空格,如:{"name": "张三",\n "age": 25,\n "city": "北京"}

四、处理非 UTF-8 编码数组数据

当数组中存在 GBK、GB2312 等非 UTF-8 编码字符串时,json_encode() 会返回 null,需预先转码。

1、检测字符串编码是否为 UTF-8,可使用 mb_detect_encoding()mb_check_encoding()

2、对非 UTF-8 字符串执行转码:mb_convert_encoding($str, 'UTF-8', 'GBK')

3、确保整个数组所有字符串值均为 UTF-8 编码后再调用 json_encode()

五、处理资源类型与不可序列化数据

PHP 数组中若包含资源(如文件句柄、数据库连接)、闭包、类实例等无法 JSON 化的数据,json_encode() 将失败并返回 false 或空字符串。

1、遍历数组,使用 is_resource()is_callable()gettype() 检查非法类型。

2、对检测出的非法值统一替换为 null 或字符串占位符,例如:$item = is_resource($item) ? null : $item;

3、完成清洗后,再执行 json_encode()

标签:# 数据库  # 适用于  # 均为  # 遍历  # 句柄  # 如果您  # 序列化  # 换行  # 组中  # 第二个  # 北京  # php  # 闭包  # 字符串  # 关联数组  # 常量  # NULL  # 格式化输出  # 编码  # json  # js  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!