13

我知道有很多问题和我一样关心,但我希望你能帮助我找到另一个解决方案。

我们的项目使用Symfony 2.5.10PHP 5.4.44MySQL 4.1.20

每当我尝试登录系统或任何涉及连接到数据库的行为(例如,使用 FOS 命令添加新用户)时,我都会收到此错误:

SQLSTATE[HY000] [2000] mysqlnd 无法使用旧的不安全身份验证连接到 MySQL 4.1+。请使用管理工具通过命令 SET PASSWORD = PASSWORD('your_existing_password') 重置密码。这将在 mysql.user 中存储一个新的、更安全的哈希值。如果此用户在 PHP 5.2 或更早版本执行的其他脚本中使用,您可能需要从 my.cnf 文件中删除 old-passwords 标志

我们已经尝试设置old_passwordsmy.cnf0,重启 mysql,为 mysql 用户设置新密码,然后再次重启 mysql,但还是一样。每当我们在查询窗口中运行它时:

SELECT user, Length(Password) FROM mysql.user;

它仍然显示 16 作为我们正在使用的用户的密码长度。并且在检查 mysql 服务器变量和设置时old passwords也是ON(即使我们已经在 my.cnf 中将 old_password 设置为 0)。

这有什么问题?我将衷心感谢您的帮助。

更新:与此同时,我们删除了 db 用户的密码,以便我们能够访问数据库。但是我仍在寻找其他解决方案,因为我在网上找到的那些解决方案(例如old_passwords=1在 my.cnf 中删除或注释掉,将 old_passwords 设置为 0 并设置新密码然后重新启动)对我不起作用。

另一个更新:通常,这个问题的解决方案是old_passwords在 mysql 中启动,但是,如PHP 文档中所述,

新的 mysqlnd 库不读取 mysql 配置文件 (my.cnf/my.ini)。

那么这是否意味着设置old_passwords为 in 0 inmy.cnf没有用?我还没有想出解决这个问题的办法。

我们需要升级使用的任何平台吗?在此先感谢您的帮助。

4

2 回答 2

4

MySQL 服务器 5.7.6 中不推荐使用“SET PASSWORD”。

5.7.6 以下的服务器要遵循的语法是,

SET PASSWORD [FOR user] = password_option
password_option: {
    PASSWORD('auth_string')
  | OLD_PASSWORD('auth_string')
  | 'hash_string'
}

服务器 5.7.6 及更高版本要遵循的语法是,

SET PASSWORD [FOR user] = password_option
password_option: {
    PASSWORD('auth_string')
  | 'auth_string'
}

另请参阅-> http://dev.mysql.com/doc/refman/5.7/en/set-password.html

于 2015-11-16T13:30:33.320 回答
2

请尝试此解决方案

http://laravel.io/forum/04-16-2014-solving-mysqlnd-cannot-connect-to-mysql-41

根据解决方案,您只需要再次设置密码并指定以新格式保存即可。

mysql> SET @@session.old_passwords = 0;
Query OK, 0 rows affected (0.00 sec)
SET PASSWORD FOR 'existinguser'@'localhost' = PASSWORD('existingpass');
Query OK, 1 rows affected (0.00 sec);
于 2015-11-10T05:48:57.850 回答