Swoole的Http2\Client用于高效发起HTTP/2请求,需编译时启用SSL和HTTP/2支持。1. 创建实例指定主机、端口及是否启用SSL(通常为true)。2. 可监听connect和error事件处理连接状态。3. 使用send()发送Swoole\Http2\Request对象,设置path、headers、cookies和data。4. 支持多路复用,在同一连接并发发送多个请求提升性能。5. 完整流程包括连接、发送请求、回调处理响应并关闭连接。注意path以/开头,建议设置User-Agent避免被拒,确保服务端支持HTTP/2。

Swoole 的 Http2\\Client 是用于发起 HTTP/2 客户端请求的类,可以高效地与支持 HTTP/2 协议的服务端通信。使用前需确保 Swoole 编译时启用了 SSL 和 HTTP/2 支持(通常通过 --enable-openssl --enable-http2 配置)。
1. 创建 Http2\\Client 实例
需要指定目标主机和端口,并设置是否使用 SSL:
$client = new Swoole\Http2\Client('localhost', 443, true); // true 表示启用 SSL
注意:HTTP/2 通常基于 HTTPS(即加密连接),所以第三个参数一般为 true。
2. 设置连接事件回调
在发送请求前,建议监听连接成功或失败的事件:
$client->on('connect', function($cli) {
echo "Connected to server\n";
});
$client->on('error', function($cli) {
echo "Connection failed\n";
});
3. 发起 HTTP/2 请求
使用 send() 方法发送一个 HTTP/2 请求。构造一个 Swoole\Http2\Request 对象并设置相关属性:
$request = new Swoole\Http2\Request();
$request->path = "/api/data";
$request->headers = [
'user-agent' => 'curl/7.68.0',
'accept' => '*/*',
];
$request->cookies = [
'session_id' => 'abc123'
];
$client->send($request, function($response) use ($client) {
echo "Status: {$response->statusCode}\n";
print_r($response->headers);
echo "Body: {$response->data}\n";
$client->close();
});
说明:
4. 支持并发多个请求
HTTP/2 支持多路复用,可以在同一个连接上并发发送多个请求:
$req1 = new Swoole\Http2\Request();
$req1->path = "/api/user";
$client->send($req1, function($resp) { echo "User: {$resp->data}\n"; });
$req2 = new Swoole\Http2\Request();
$req2->path = "/api/order";
$client->send($req2, function($resp) { echo "Order: {$resp->data}\n"; });
两个请求会同时在单个 TCP 连接上传输,提升效率。
5. 完整示例
$client = new Swoole\Http2\Client('http2.example.com', 443, true);
$client->on('connect', function($cli) {
$request = new Swoole\Http2\Request();
$request->path = "/";
$request->headers = ['user-agent' => 'swoole-http2-client'];
$cli->send($request, function($response) use ($cli) {
echo "Received response: {$response->statusCode}\n";
echo "Data: {$response->data}\n";
$cli->close();
});
});
$client->on('error', function($cli) {
echo "Connect error.\n";
});
// 开始连接
$client->connect();
基本上就这些。关键点是启用 SSL、正确构建 Request 对象、使用回调处理响应。不复杂但容易忽略细节比如 path 格式或未设置 user-agent 导致服务端拒绝。确保服务端真正支持 HTTP/2,否则会降级或连接失败。










