PHP发送HTTP请求有五种方法:一、cURL扩展(最常用,功能全面);二、file_get_contents配合stream_context_create(简单轻量);三、Guzzle库(面向对象,适合大型项目);四、PHP 8.1+内置HttpClient扩展(支持异步);五、socket原始连接(底层定制)。

如果您需要在PHP中向外部API或网页发送HTTP请求,则必须选择合适的内置函数或扩展来构建并执行请求。以下是实现此目标的多种方法:
一、使用cURL扩展发送HTTP请求
cURL是PHP中最常用且功能最强大的HTTP客户端工具,支持GET、POST、自定义头、SSL、超时控制等完整HTTP特性。
1、初始化cURL会话句柄,使用curl_init()函数创建一个新会话。
2、设置请求URL,通过curl_setopt($ch, CURLOPT_URL, 'https://api.example.com/data')指定目标地址。
立即学习“PHP免费学习笔记(深入)”;
3、启用返回响应体内容而非直接输出,设置curl_setopt($ch, CURLOPT_RETURNTRANSFER, true)。
4、可选:设置超时时间,如curl_setopt($ch, CURLOPT_TIMEOUT, 30)防止请求无限挂起。
5、可选:若需发送POST数据,设置curl_setopt($ch, CURLOPT_POST, true)并用CURLOPT_POSTFIELDS传入数组或字符串。
6、执行请求,调用curl_exec($ch)获取响应内容,并用curl_getinfo($ch)检查状态码。
7、关闭cURL会话,调用curl_close($ch)释放资源。
二、使用file_get_contents配合stream_context_create
该方法无需额外扩展,依赖PHP内置的流封装器,适用于简单GET请求或配置较轻的POST场景,但灵活性低于cURL。
1、构造请求选项数组,例如设置method为'GET'或'POST',header为请求头字段。
2、若为POST请求,将数据编码为application/x-www-form-urlencoded格式,并写入content选项。
3、调用stream_context_create($options)生成上下文资源。
4、将上下文传入file_get_contents('https://api.example.com/data', false, $context)发起请求。
5、检查返回值是否为false,若是则说明请求失败,可通过error_get_last()获取错误信息。
三、使用Guzzle HTTP客户端库
Guzzle是一个第三方PSR-7兼容HTTP客户端,提供面向对象接口和中间件支持,适合中大型项目维护。
1、通过Composer安装:执行composer require guzzlehttp/guzzle引入库文件。
2、在PHP脚本中引入自动加载器:require 'vendor/autoload.php'。
3、实例化GuzzleHttp\Client对象,可传入默认配置如base_uri、timeout等。
4、调用$client->get('users')或$client->post('login', ['form_params' => ['user'=>'a','pass'=>'b']])发起请求。
5、使用$response->getStatusCode()获取状态码,$response->getBody()->getContents()读取响应体。
四、使用PHP内置的HTTP客户端(PHP 8.1+)
PHP 8.1起引入了新的HttpClient扩展(experimental),提供异步能力与现代API设计,但需确认运行环境已启用该扩展。
1、检查扩展是否可用:调用extension_loaded('http')返回true方可继续。
2、使用Urn\Uri类构造请求URI,例如$uri = new Uri('https://api.example.com/test')。
3、构建Request对象,传入方法、URI及可选Headers和Body。
4、调用HttpClient::request($request)执行同步请求,或HttpClient::sendAsyncRequest()发起异步调用。
5、从Response对象中提取getStatusCode()、getHeaderLine('Content-Type')及getBody()->toString()等信息。
五、使用socket原始连接发送HTTP请求
该方式绕过所有高层封装,直接操作TCP套接字,用于教学理解HTTP协议本质或特殊协议定制场景。
1、使用fsockopen()连接目标主机的80(HTTP)或443(HTTPS)端口,HTTPS需配合stream_socket_enable_crypto()启用TLS。
2、手动拼接HTTP请求行与头部,例如"GET /data HTTP/1.1\r\nHost: api.example.com\r\nConnection: close\r\n\r\n"。
3、使用fwrite()将请求字符串写入socket流。
4、使用fgets()或stream_get_contents()逐行或整块读取响应,注意解析状态行与空行分隔符。
5、关闭socket连接,调用fclose($fp)释放资源。











