答案:PHP中调用外部API主要有cURL和file_get_contents两种方式;cURL功能强大,支持自定义请求头、多种HTTP方法及复杂配置,适合复杂场景;file_get_contents语法简洁,仅适用于简单GET请求;若需发送POST、设置头信息或处理证书,则应使用cURL。

在PHP中调用外部API是开发中常见的需求,比如获取天气数据、用户信息或第三方服务接口。实现方式主要有两种:使用cURL扩展和使用file\_get\_contents函数。两者各有优劣,适用于不同场景。
cURL请求API
cURL是PHP中功能强大的网络请求工具,支持多种协议,能灵活控制HTTP头、Cookie、超时、代理等参数,适合复杂请求场景。
优点:
- 可自定义请求头、请求方法(GET/POST/PUT等)
- 支持HTTPS证书验证、代理设置
- 可设置超时时间、错误处理更精细
- 能处理POST数据、上传文件
示例:使用cURL发送GET请求
立即学习“PHP免费学习笔记(深入)”;
function apiRequestWithCurl($url) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 30);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 测试环境可关闭验证
$response = curl_exec($ch);
$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);
if ($response === false) {
return ['error' => '请求失败'];
}
return ['data' => json_decode($response, true), 'code' => $httpCode];
}
// 调用示例
$result = apiRequestWithCurl('https://api.example.com/data');
print_r($result);
file\_get\_contents请求API
file\_get\_contents是PHP内置函数,可以读取文件或URL内容,使用简单,适合快速获取远程数据。
优点:
- 语法简洁,无需初始化句柄
- 适合简单的GET请求
- 代码量少,易于理解
注意:需开启allow\_url\_fopen(默认开启),不支持复杂配置。
示例:使用file\_get\_contents发送GET请求
function apiRequestWithFileGetContents($url) {
$context = stream_context_create([
'http' => [
'method' => 'GET',
'timeout' => 30,
'header' => "User-Agent: PHP\r\n"
]
]);
$response = file_get_contents($url, false, $context);
if ($response === false) {
return ['error' => '请求失败'];
}
return ['data' => json_decode($response, true)];
}
// 调用示例
$result = apiRequestWithFileGetContents('https://api.example.com/data');
print_r($result);
如何选择?
如果只是获取公开的JSON接口数据,且不需要POST或其他复杂操作,file\_get\_contents足够用,代码更简洁。
如果需要:
- 发送POST、PUT、DELETE请求
- 添加Authorization头(如Bearer Token)
- 处理重定向、Cookie、证书
- 调试响应状态码或请求耗时
那么推荐使用cURL,它提供了完整的控制能力。
基本上就这些,根据项目需求选择合适的方式即可。











