mysqli_connect() 返回 false 的原因需用 mysqli_connect_error() 查看具体错误:Connection refused 表示服务未启动或端口错误;Access denied 是账号密码或 host 权限不匹配;Unknown MySQL server host 是主机名错误或 DNS 不通。
mysqli_connect() 返回 false 的具体原因PHP 连不上数据库,mysqli_connect() 直接返回 false 是最常见现象。它不报错,只沉默失败,所以必须主动查错误信息。
mysqli_connect() 后加 mysqli_connect_error(),比如:if (!$conn) {
die('连接失败: ' . mysqli_connect_error());
}Connection refused 表示服务没启或端口不对;Access denied for user 是账号密码/权限问题;Unknown MySQL server host 是主机名写错或 DNS 不通mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT),错误会抛异常而非返回 false,此时要用 try/catch
PHP 报错只是表象,底层常是服务不可达。别急着改 PHP 代码,先验证基础设施。
mysql -h 127.0.0.1 -P 3306 -u root -p(注意 -P 是大写,指定端口)localhost 连不上,大概率是 MySQL 把 localhost 解
析为 socket 连接,而 PHP 配置了 TCP;换成 127.0.0.1 就绕过这个问题netstat -tuln | grep :3306 确认 mysqld 确实在监听;防火墙(ufw 或 firewalld)可能拦了 3306 端口Access denied 错误里最容易被忽略的是 host 字段——MySQL 用户是 'user'@'host' 成对存在的,不是只看用户名。
SELECT User, Host FROM mysql.user; 查看实际用户记录,注意 Host 列是否为 %、localhost、127.0.0.1 或具体 IP127.0.0.1 连,就必须有 'myuser'@'127.0.0.1' 或 'myuser'@'%';用 localhost 连,则需要 'myuser'@'localhost'
FLUSH PRIVILEGES;,否则权限不生效PDO 默认静默失败,错误信息藏得更深,必须显式开启异常模式并捕获。
立即学习“PHP免费学习笔记(深入)”;
$pdo = new PDO($dsn, $user, $pass, [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
]);PDOException,$e->getMessage() 就是真实错误,比如 SQLSTATE[HY000] [2002] No such file or directory 表示 socket 路径不对localhost),DSN 中要显式指定 unix_socket=/var/run/mysqld/mysqld.sock,否则 PDO 可能用错路径