php - 为什么 PHP 卡在 mysqli_connect 而没有错误代码?

标签 php linux mysqli apache2 mariadb

在线

$conn = mysqli_connect($dbServername, $dbUsername, $dbPassword, $dbName);

PHP 停止且没有错误。

这是一个新的 Linux 服务器,运行 PHP 7.0、Apache 2 和 MariaDB 10。我不知道为什么我在运行 MariaDB,即使我安装了包“mysql-server”。我读到它们是兼容的,所以我认为应该没问题。我尝试在另一台机器 (Raspberry Pi 3) 上设置我的服务器,结果相同。

<?php

$dbServername = "localhost";
echo "passed dbServername <br>";
$dbUsername = "root";
echo "passed dbUsername <br>";
$dbPassword = "";
echo "passed dbPassword <br>";
$dbName = "cities";
echo "passed dbName <br>";

$conn = mysqli_connect($dbServername, $dbUsername, $dbPassword, $dbName);
echo "passed conn <br>";

if (!$conn) {
    echo "Error: Unable to connect to MySQL." . PHP_EOL;
    echo "Debugging errno: " . mysqli_connect_errno() . PHP_EOL;
    echo "Debugging error: " . mysqli_connect_error() . PHP_EOL;
    exit;
} else {
    echo "success! <br>";
}
?>

这是我的网页输出:

passed dbServername
passed dbUsername
passed dbPassword
passed dbName 

绝对没有别的。无论是否连接,我都希望有更多的输出。

编辑:

有趣的是,如果我像这样插入错误报告:

$dbServername = "localhost";
echo "passed dbServername <br>";
$dbUsername = "root";
echo "passed dbUsername <br>";

mysqli_report(MYSQLI_REPORT_ALL);

$dbPassword = "";
echo "passed dbPassword <br>";
$dbName = "cities";
echo "passed dbName <br>";

我得到输出:

passed dbServername
passed dbUsername 

所以看起来通过添加任何与 MySqli 相关的东西都会卡住 PHP。

没有错误报告,当我查看它显示的源代码时:

passed dbServername <br>passed dbUsername <br>passed dbPassword <br>passed dbName <br>

最佳答案

我知道这是 7 个月大,但我遇到了同样的问题。

我的解决方案很简单: 我还没有安装 php-mysql!

在 Ubuntu 中运行

apt install php-mysql

关于php - 为什么 PHP 卡在 mysqli_connect 而没有错误代码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55311209/

相关文章:

php - 迁移到 mysqli

PHP 删除功能不起作用

php - codeigniter文件上传失败

php - 值未插入 WordPress 表中

php - 使用 AWS DynamoDB 和 PHP 进行分页

c - 为主线程设置栈

php - 使用 Zend_Db 时 pdo_mysql 与 mysqli

php - REST API - 为什么使用 PUT DELETE POST GET?

原始模式下的Python stdin 打印添加空格

linux - 如何使用awk打印路径文件名的尾部