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










