PHP中无法通过Composer安装Python的requests库,应使用Guzzle 7+(支持PSR-18)或Symfony HTTP Client替代;手动封装curl易出错,推荐使用成熟HTTP客户端并注意状态码、JSON解析、SSL验证等细节。

Composer安装requests库根本行不通
Requests 是 Python 的 HTTP 库,不是 PHP 的 —— composer require requests 会报错:Could not find package requests。PHP 生态里没有同名官方库,强行搜到的第三方 rmccue/requests 已多年未维护(最后更新在 2016 年),不兼容 PHP 8+,也不支持 PSR-7 / PSR-18,不建议用于新项目。
PHP 该用什么替代 Requests?推荐 Guzzle + PSR-18
现代 PHP 发送 HTTP 请求,应优先使用符合 PSR-18 标准的客户端。Guzzle 7+ 是最成熟的选择,它自带 PSR-18 兼容层,且生态完善、文档清晰、错误提示友好。
-
composer require guzzlehttp/guzzle:^7.5(PHP 8.0+ 推荐) - 若项目已用
psr/http-client-implementation,可只装轻量实现如composer require symfony/http-client - 不用
curl_init()手写封装 —— 易漏超时、重定向、JSON 解析异常等边界处理
一个能直接跑的 Guzzle GET 示例
以下代码发请求、自动解析 JSON、带基础错误处理,复制即用:
5.0]);
try {
$response = $client->get('https://httpbin.org/json');
$data = $response->getBody()->getContents();
$json = json_decode($data, true);
var_dump($json['slideshow']['title'] ?? 'no title');
} catch (RequestException $e) {
echo '请求失败:' . $e->getMessage();
}
注意:getContents() 是阻塞读取,大响应体建议用 stream 模式;json_decode 前务必检查 $response->getStatusCode() === 200。
常见踩坑点:SSL、代理、Form 表单提交
Guzzle 默认校验证书,内网或测试环境遇到 cURL error 60: SSL certificate problem,临时解决加配置:
- 跳过证书验证(仅开发):
['verify' => false](别放生产) - 指定 CA 路径:
['verify' => '/path/to/cacert.pem'] - 走代理:
['proxy' => 'http://127.0.0.1:8080'] - 发 Form 表单:
$client->post($url, ['form_params' => ['key' => 'value']]),不是json参数
真正麻烦的从来不是“怎么装”,而是请求发出去后状态码没判断、JSON 解析前没验 content-type、大文件上传没设 multipart、重试逻辑没配 —— 这些细节比选库重要得多。









