答案:配置 Swoole HTTPS 需创建 SSL 模式的 HTTP 服务器并指定证书路径。使用 SWOOLE_SOCK_TCP | SWOOLE_SSL 模式,设置 ssl_cert_file 和 ssl_key_file 为绝对路径,确保证书为 PEM 格式且私钥无密码。可直接运行或通过 Nginx 反向代理,启动后测试 HTTPS 访问并检查端口、权限与证书完整性。

要在 Swoole 中配置 SSL 证书实现 HTTPS,关键在于创建一个启用 SSL 的 HTTP 服务器,并正确指定证书文件路径。Swoole 原生支持 HTTPS,只需在创建服务器时设置相关 SSL 选项即可。
Swoole 提供了 SWOOLE_SOCK_TCP | SWOOLE_SSL 模式来开启加密连接。你需要准备 SSL 证书文件(通常是 .crt 和 .key 文件),然后在服务器配置中加载它们。
示例代码:
<pre class="brush:php;toolbar:false;">$server = new Swoole\Http\Server("0.0.0.0", 443, SWOOLE_PROCESS, SWOOLE_SOCK_TCP | SWOOLE_SSL);
$server->set([
'ssl_cert_file' => '/path/to/your/fullchain.crt',
'ssl_key_file' => '/path/to/your/private.key',
'worker_num' => 2,
]);
$server->on('Request', function ($request, $response) {
$response->header('Content-Type', 'text/plain');
$response->end("Hello HTTPS via Swoole!");
});
$server->start();
确保你提供的证书路径是绝对路径且可读。常见的错误包括路径写错、权限不足或使用相对路径导致加载失败。
你可以选择让 Swoole 直接对外提供 HTTPS 服务,也可以放在 Nginx 后面反向代理。
直接使用 Swoole 处理 HTTPS 更高效,但需要开放 443 端口并确保主进程有权限读取证书。
若使用 Nginx,可关闭 Swoole 的 SSL 配置,由 Nginx 终止 SSL 连接,再通过 HTTP 转发请求给 Swoole。
启动服务后,用浏览器或 curl 访问 https://your-domain.com,确认能否正常响应。
如果无法连接,检查以下几点:
基本上就这些。只要证书正确、路径无误、端口开放,Swoole 就能顺利运行 HTTPS 服务。
以上就是Swoole怎么配置SSL证书实现HTTPS的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号