登录
首页 >  文章 >  php教程

PHP用curl发送POST数据教程

时间:2026-05-31 15:22:43 252浏览 收藏

本文深入解析了PHP中使用cURL发送POST请求的核心要点与常见陷阱,重点强调必须显式设置`CURLOPT_POST => true`和`CURLOPT_POSTFIELDS`才能真正发起有效POST;清晰对比了传递关联数组(自动URL编码、默认表单类型)与传递JSON字符串(需手动设置`Content-Type: application/json`且务必检查`json_encode`结果)两种场景的关键区别;同时揭露了“后端$_POST为空”等典型问题的真实原因——往往并非cURL配置错误,而是服务端解析配置、HTTPS证书验证、Host头缺失或未做基础错误处理所致,并附上带完整异常捕获的可运行示例,助你一次写对、快速排障。

PHP请求POST网址用curl怎样传数据_PHPcurl传POST数据法【提交】

curl_setopt 设置 POST 方法和数据体

PHP 用 curl_setopt 发送 POST 请求,核心是两步:告诉 cURL 用 POST 方法,再把数据塞进请求体。不设 CURLOPT_POST 或漏掉 CURLOPT_POSTFIELDS,请求就还是 GET,或者发空体。

  • CURLOPT_POST => true 是开关,必须显式设为 true(不能只设 1,某些旧版本会出问题)
  • CURLOPT_POSTFIELDS 接收数组或字符串:传数组会自动编码成 application/x-www-form-urlencoded;传 JSON 字符串则需手动设 Content-Type
  • 如果目标接口要 application/json,得额外加 CURLOPT_HTTPHEADER,比如 ['Content-Type: application/json']

传数组 vs 传 JSON 字符串的区别

很多人卡在“为什么后端收不到数据”,其实是没分清两种常见场景的数据格式和 header 配合方式。

  • 传关联数组:curl_setopt($ch, CURLOPT_POSTFIELDS, ['name' => '张三', 'age' => 25]) → 自动 urlencode,body 是 name=%E5%BC%A0%E4%B8%89&age=25,header 默认是 application/x-www-form-urlencoded
  • 传 JSON:curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode(['name' => '张三', 'age' => 25])) → body 是原始 JSON 字符串,但必须手动加 Content-Type: application/json,否则后端可能当普通表单解析失败
  • 注意:json_encode 返回 false 时(比如含非法 UTF-8 字符),CURLOPT_POSTFIELDS 会收到 null,导致发空请求 —— 建议加 if (false === $json = json_encode(...)) { die('JSON encode failed'); }

常见错误:POST 成功但后端 $_POST 为空

这通常不是 cURL 问题,而是服务端环境或 PHP 配置导致的解析失败。

  • 检查目标服务器是否禁用了 php://input(影响 raw body 读取),或 enable_post_data_reading = Off(极少见,但会导致 $_POST 始终为空)
  • file_get_contents('php://input') 在后端打印原始输入,确认数据确实到达 —— 如果有内容但 $_POST 空,说明是编码或 content-type 不匹配
  • cURL 默认不发 Host 头,某些 Nginx 配置下会 400;可加 ['Host: example.com']CURLOPT_HTTPHEADER 排查
  • 别忽略 HTTPS 证书验证:开发时临时关掉 CURLOPT_SSL_VERIFYPEER => falseCURLOPT_SSL_VERIFYHOST => false,但上线前必须恢复

完整可运行示例(带错误处理)

以下是最小可靠模板,覆盖最常用表单提交场景:

$ch = curl_init('https://httpbin.org/post');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, ['user_id' => 123, 'token' => 'abc']);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);

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

if ($error) {
    die("cURL error: $error");
}
if ($httpCode !== 200) {
    die("HTTP $httpCode");
}
echo $response;

真正容易被忽略的是:每次 curl_exec 后必须检查 curl_errorcurl_getinfo(..., CURLINFO_HTTP_CODE) —— 很多“没反应”其实是 500 或超时,但代码没捕获就静默失败了。

以上就是《PHP用curl发送POST数据教程》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>