1

假设我们服务器的 ip 是 55.555.555.55。还可以说我们有一个 mysql 用户'user'@'localhost'

那么,为什么这会返回权限错误

$mysql_server = "55.555.555.55";
$mysql_user = "";
$mysql_password = "";
$mysql_db = "";
$mysqli = new mysqli($mysql_server, $mysql_user, $mysql_password, $mysql_db);
if ($mysqli->connect_errno) {
printf("Connection failed: %s \n", $mysqli->connect_error);
exit();
}
$mysqli->set_charset("utf8");

但这并不

$mysql_server = "localhost";
$mysql_user = "";
$mysql_password = "";
$mysql_db = "";
$mysqli = new mysqli($mysql_server, $mysql_user, $mysql_password, $mysql_db);
if ($mysqli->connect_errno) {
printf("Connection failed: %s \n", $mysqli->connect_error);
exit();
}
$mysqli->set_charset("utf8");

55.555.555.55 和 localhost 不是一回事吗?这不应该是一个问题。

4

1 回答 1

2

不,localhostMySQL 将其视为绕过 TCP/IP。它使用 UNIX 套接字。即使用户名和密码相同,您也需要mysql.user权限表中的两行来授权这两种访问方法。

通配符'%'匹配任何 IP 地址或主机名,但匹配 localhost。这可能违反直觉,但这是 MySQL 的工作方式。

这在这里解释:http: //dev.mysql.com/doc/refman/5.6/en/connecting.html

于 2013-05-18T22:01:20.527 回答