为了账号安全,请及时绑定邮箱和手机立即绑定

用户'root'@'localhost'的访问被拒绝(使用密码:是)(Mysql :: Error)

用户'root'@'localhost'的访问被拒绝(使用密码:是)(Mysql :: Error)

精慕HU 2019-09-24 15:24:49
我试图在服务器上部署Web应用程序,但出现此mysql数据库异常Access denied for user 'root'@'localhost' (using password: YES) (Mysql::Error)我试图使用mysql -u root -p所有的数据库操作从命令提示符处访问数据库。有什么错误java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2928)    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:771)    at com.mysql.jdbc.MysqlIO.secureAuth411(MysqlIO.java:3649)    at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1176)    at com.mysql.jdbc.Connection.createNewIO(Connection.java:2558)    at com.mysql.jdbc.Connection.<init>(Connection.java:1485)    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)    at java.sql.DriverManager.getConnection(DriverManager.java:620)    at java.sql.DriverManager.getConnection(DriverManager.java:200)    at com.mpigeon.DbConnection.DbConn(DbConnection.java:26)    at com.mpigeon.CheckLoginHome.doGet(CheckLoginHome.java:39)    at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
查看完整描述

4 回答

?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

尝试使用root像..


mysql -uroot

然后您可以使用登录后检查其他用户和主机


select user,host,password from mysql.user;


查看完整回答
反对 回复 2019-09-24
?
MMMHUHU

TA贡献1834条经验 获得超8个赞

将MySQL服务器从5.1.73升级到5.5.45后,我遇到了相同的错误。还有另一种方法可以修复该错误。


就我而言,我能够使用root密码连接到MySQL,但是MySQL主动拒绝向任何用户授予特权。


以root身份连接到MySQL


mysql -u root -p

然后输入您的MySQL root密码;


选择数据库;


use mysql;

最有可能的是,mysql.user表中的根记录只有一个记录,只允许从中进行连接localhost(在我的例子中),但是默认情况下,根目录应该有两个记录,一个为localhost,另一个为127.0.0.1;


为根用户创建其他记录(Host='127.0.0.1'如果不存在);


    SET @s = CONCAT('INSERT INTO mysql.user SELECT ',

            REPLACE((SELECT GROUP_CONCAT(COLUMN_NAME) 

                     FROM INFORMATION_SCHEMA.COLUMNS

                     WHERE TABLE_NAME = 'user' AND TABLE_SCHEMA = 'mysql')

            ,"Host","'127.0.0.1'"),

            ' FROM mysql.user WHERE User="root"'); 


     PREPARE stmt FROM @s; 

     EXECUTE stmt;

除此之外,您还可以执行mysql_upgrade -u -p 查看一切是否正常。


查看完整回答
反对 回复 2019-09-24
?
万千封印

TA贡献1891条经验 获得超3个赞

根据我在这里的回答,认为这可能有用:


我尝试了许多步骤来纠正此问题。有很多解决此问题的方法的资源,很难从废话中滤除它的含义。我终于在这里找到了一个很好的解决方案:


步骤1:识别数据库版本


$ mysql --version

您将在MySQL中看到类似以下的输出:


$ mysql  Ver 14.14 Distrib 5.7.16, for Linux (x86_64) using  EditLine wrapper

或对于MariaDB这样的输出:


mysql  Ver 15.1 Distrib 5.5.52-MariaDB, for Linux (x86_64) using readline 5.1

记下您正在运行哪个数据库和哪个版本,以备后用。接下来,您需要停止数据库,以便可以手动访问它。


步骤2:停止数据库服务器


要更改root密码,您必须事先关闭数据库服务器。


您可以使用以下方法对MySQL执行此操作:


$ sudo systemctl stop mysql

对于MariaDB,具有:


$ sudo systemctl stop mariadb

步骤3:在没有权限检查的情况下重新启动数据库服务器


如果您在运行MySQL和MariaDB时未加载有关用户特权的信息,则它将允许您以root特权访问数据库命令行而无需提供密码。这将允许您在不知道数据库的情况下访问数据库。


为此,您需要使数据库停止加载存储用户特权信息的授权表。因为这有一定的安全隐患,所以您还应该跳过联网,以防止其他客户端连接。


在不加载授权表或启用网络的情况下启动数据库:


$ sudo mysqld_safe --skip-grant-tables --skip-networking &

该命令末尾的&符号将使此过程在后台运行,因此您可以继续使用终端。


现在,您可以以root用户身份连接到数据库,该用户不需要密码。


$ mysql -u root

您将立即看到数据库外壳提示。


MySQL提示


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


mysql>

MariaDB提示


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


MariaDB [(none)]>

现在您具有root用户访问权限,可以更改root用户密码。


步骤4:更改根密码


mysql> FLUSH PRIVILEGES;

现在,我们可以实际更改root密码了。


对于MySQL 5.7.6和更高版本以及MariaDB 10.1.20和更高版本,请使用以下命令:


mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';

对于MySQL 5.7.5和更高版本以及MariaDB 10.1.20和更高版本,请使用:


mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('new_password');

确保new_password用您选择的新密码替换。


注意:如果ALTER USER命令不起作用,通常表明存在更大的问题。但是,您可以尝试UPDATE ... SET重设root密码。


[重要]这是解决我的特定问题的特定行:


mysql> UPDATE mysql.user SET authentication_string = PASSWORD('new_password') WHERE User = 'root' AND Host = 'localhost';

请记住,此后要重新加载授权表。


无论哪种情况,您都应该看到确认命令已成功执行的信息。


Query OK, 0 rows affected (0.00 sec)

密码已更改,因此您现在可以停止数据库服务器的手动实例,然后像以前一样重新启动它。


步骤5:正常重启数据库服务器


本教程将进行进一步的步骤来重新启动数据库,但是我唯一使用的部分是:


对于MySQL,请使用: $ sudo systemctl start mysql


对于MariaDB,请使用:


$ sudo systemctl start mariadb

现在,您可以通过运行以下命令确认新密码已正确应用:


$ mysql -u root -p

现在,该命令将提示您输入新分配的密码。输入它,您应该可以按预期访问数据库提示。


结论


现在,您可以恢复对MySQL或MariaDB服务器的管理权限。确保您选择的新的root密码是安全的,并将其放在安全的地方。


查看完整回答
反对 回复 2019-09-24
  • 4 回答
  • 0 关注
  • 6839 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信