以下是 PHP OpenSSL 扩展安装的完整指南,涵盖 Linux (Ubuntu/CentOS)、Windows 和 macOS 系统,并包含故障排查方法:
1. Linux 系统安装(Ubuntu/Debian)
(1) 安装 OpenSSL 依赖库
sudo apt update
sudo apt install openssl libssl-dev
(2) 安装 PHP OpenSSL 扩展
# 对于 PHP 8.2(版本可替换)
sudo apt install php8.2-openssl
(3) 启用扩展
sudo phpenmod openssl # 启用模块
sudo systemctl restart apache2 # 或 nginx/php-fpm
(4) 验证安装
php -m | grep openssl # 应输出 "openssl"
php -i | grep "OpenSSL support" # 检查是否启用
2. Linux 系统安装(CentOS/RHEL)
(1) 安装依赖
sudo yum install openssl openssl-devel
(2) 安装 PHP 扩展
# 通过 Remi 仓库(推荐)
sudo yum install php-openssl
(3) 重启服务
sudo systemctl restart httpd # Apache
sudo systemctl restart php-fpm # PHP-FPM
3. Windows 系统安装
(1) 编辑 php.ini
- 找到 PHP 安装目录(如
C:\php\
) - 打开
php.ini
文件 - 取消注释以下行:
extension=openssl
(2) 检查依赖
- 确保
php_openssl.dll
存在于ext
目录 - 系统环境变量
PATH
应包含 PHP 安装路径
(3) 重启 Web 服务
- 重启 Apache/Nginx 或 IIS
4. macOS 系统安装(Homebrew)
(1) 安装 OpenSSL
brew install openssl
(2) 链接库文件
brew link openssl --force
(3) 重新编译 PHP(若手动编译)
./configure --with-openssl=$(brew --prefix openssl)
make && sudo make install
5. 编译安装(通用方法)
(1) 进入 PHP 源码目录
cd php-8.2.0 # 替换为你的 PHP 版本
cd ext/openssl
(2) 编译安装
phpize
./configure
make
sudo make install
(3) 添加扩展
# php.ini 中添加
extension=openssl.so
6. 故障排查
(1) 检查扩展是否加载
php -m | grep openssl
- 如果未显示,检查
php.ini
路径:php --ini | grep "Loaded Configuration"
(2) 常见错误解决
错误 | 解决方案 |
---|---|
undefined symbol: EVP_idea_cbc | 重新编译 PHP 并指定 OpenSSL 路径:--with-openssl=/usr/include/openssl |
Unable to load dynamic library | 确认 php_openssl.dll (Windows) 或 openssl.so (Linux) 文件存在且路径正确 |
(3) 日志分析
tail -f /var/log/apache2/error.log # Apache
journalctl -u php-fpm --no-pager -n 50 # PHP-FPM
7. 验证 OpenSSL 功能
<?php
echo "OpenSSL 支持: " . (extension_loaded('openssl') ? '是' : '否');
echo "\n支持的加密算法:\n";
print_r(openssl_get_cipher_methods());
?>
访问该脚本应输出支持的加密算法列表。
8. 升级 OpenSSL(安全建议)
# Ubuntu
sudo apt upgrade openssl
# CentOS
sudo yum update openssl
# 重新启动 PHP 服务
sudo systemctl restart php-fpm
通过以上步骤, PHP 环境将完整支持 OpenSSL 扩展,可正常用于 HTTPS 请求、MQTT TLS 加密、数据签名 等场景。