0

0

PHP 中正确发送嵌套多维 JSON 数据的 POST 请求完整教程

花韻仙語

花韻仙語

发布时间:2026-03-05 09:08:12

|

531人浏览过

|

来源于php中文网

原创

PHP 中正确发送嵌套多维 JSON 数据的 POST 请求完整教程

本文详解如何在 PHP 中正确构造并发送包含深层嵌套结构的 JSON 对象(如消息平台 API 所需),避免因误用 http_build_query() 导致数据损坏,重点演示 json_encode() + cURL 的标准实践。

本文详解如何在 php 中正确构造并发送包含深层嵌套结构的 json 对象(如消息平台 api 所需),避免因误用 `http_build_query()` 导致数据损坏,重点演示 `json_encode()` + `curl` 的标准实践。

在 PHP 中向第三方 API(如 CM.com 消息平台)提交嵌套多维 JSON 数据时,一个常见误区是将 JSON 字符串直接赋值给变量后,错误地使用 http_build_query() 处理——这会把整个 JSON 当作扁平键值对编码为 x-www-form-urlencoded 格式,彻底破坏原始嵌套结构(例如对象变字符串、数组变索引键等),最终导致 API 拒绝请求或解析失败。

✅ 正确做法是:保持数据为原生 PHP 数组(或对象),调用 json_encode() 序列化为标准 JSON 字符串,并显式设置 Content-Type: application/json 请求头。以下是完整、可运行的解决方案:

✅ 正确发送嵌套 JSON 的推荐代码

<?php
// 1. 直接以 PHP 关联数组形式定义嵌套结构(推荐:语义清晰、类型安全)
$data = [
    'messages' => [
        'authentication' => [
            'productToken' => 'your product token'
        ],
        'msg' => [
            [
                'body' => [
                    'type'    => 'auto',
                    'content' => 'Fallback Text for SMS'
                ],
                'to' => [
                    ['number' => '00316012345678']
                ],
                'from' => '00316098765432',
                'allowedChannels' => ['WhatsApp'],
                'richContent' => [
                    'conversation' => [
                        ['text' => 'A text message with *bold* formatting in a speech bubble.'],
                        ['text' => 'Another speech bubble'],
                        [
                            'media' => [
                                'mediaName' => 'and an image',
                                'mediaUri'  => 'https://www.cm.com/cdn/web/nl-nl/blog/conversational-commerce.jpg',
                                'mimeType'  => 'image/jpeg'
                            ]
                        ]
                    ]
                ]
            ]
        ]
    ]
];

// 2. JSON 编码(确保 UTF-8 安全,处理特殊字符)
$json_payload = json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);
if ($json_payload === false) {
    throw new RuntimeException('JSON 编码失败: ' . json_last_error_msg());
}

// 3. 配置 cURL 发送 application/json 请求
$url = 'https://api.cm.com/messages'; // 替换为实际 API 地址
$ch = curl_init();
curl_setopt_array($ch, [
    CURLOPT_URL            => $url,
    CURLOPT_POST           => true,
    CURLOPT_POSTFIELDS     => $json_payload,              // 传递原始 JSON 字符串
    CURLOPT_HTTPHEADER     => [
        'Content-Type: application/json',
        'Content-Length: ' . strlen($json_payload)  // 可选但推荐
    ],
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_TIMEOUT        => 30,
    CURLOPT_SSL_VERIFYPEER => false // 生产环境请设为 true 并配置 CA 证书
]);

$response = curl_exec($ch);
$http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
$error = curl_error($ch);
curl_close($ch);

// 4. 处理响应
if ($error) {
    echo "cURL 错误: $error";
} elseif ($http_code >= 200 && $http_code < 300) {
    $result = json_decode($response, true);
    echo "请求成功!响应: <pre class="brush:php;toolbar:false;">" . htmlspecialchars(print_r($result, true)) . "
"; } else { echo "HTTP 错误码: $http_code,响应: " . htmlspecialchars($response); } ?>

⚠️ 关键注意事项

  • ❌ 禁止使用 http_build_query($array):它专用于 application/x-www-form-urlencoded,会将 ['msg' => [['to' => [['number' => '...']]]]] 错误转为 msg[0][to][0][number]=...,API 无法识别。
  • ✅ 必须设置 Content-Type: application/json:这是服务端正确解析 JSON 的前提,缺失该头可能导致 415 Unsupported Media Type 错误。
  • ✅ 使用 json_encode() 而非手动拼接 JSON 字符串:避免引号、转义、编码问题(如中文乱码),JSON_UNESCAPED_UNICODE 保证中文不被 \uXXXX 编码。
  • ✅ 始终校验 json_encode() 返回值:若输入含不可序列化类型(如资源、闭包),返回 false,需及时捕获。
  • ? 调试技巧:发送前 echo $json_payload; exit; 查看实际发出的 JSON 是否符合 API 文档要求(推荐用 JSONLint 格式化验证)。

? 补充:若你只有 JSON 字符串(而非数组)

若原始数据来自文件或外部输入(如 $json_string = file_get_contents('payload.json');),应先 json_decode($json_string, true) 转为数组再编码,不要直接发送原始字符串(除非确认其已严格符合 API 要求且无额外空格/注释):

Genspark
Genspark

Genspark 是一款创新的 AI 搜索引擎,致力于提供比传统搜索引擎更高效、准确和无偏见的信息获取方式。

下载
// 安全解码 + 重编码(清理潜在格式问题)
$parsed = json_decode($json_string, true);
if ($parsed === null) {
    throw new InvalidArgumentException('无效 JSON 输入: ' . json_last_error_msg());
}
$json_payload = json_encode($parsed, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);

掌握这一模式,即可稳定、可靠地对接任何要求 application/json 的现代 RESTful API,彻底规避“多维 JSON 发送失败”的典型陷阱。

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

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
PHP API接口开发与RESTful实践
PHP API接口开发与RESTful实践

本专题聚焦 PHP在API接口开发中的应用,系统讲解 RESTful 架构设计原则、路由处理、请求参数解析、JSON数据返回、身份验证(Token/JWT)、跨域处理以及接口调试与异常处理。通过实战案例(如用户管理系统、商品信息接口服务),帮助开发者掌握 PHP构建高效、可维护的RESTful API服务能力。

178

2025.11.26

json数据格式
json数据格式

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

452

2023.08.07

json是什么
json是什么

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

546

2023.08.23

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

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

331

2023.10.13

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

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

81

2025.09.10

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

454

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

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

精品课程

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

共137课时 | 13万人学习

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号