第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

用戶'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;


為根用戶創(chuàng)建其他記錄(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;

除此之外,您還可以執(zhí)行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執(zhí)行此操作:


$ sudo systemctl stop mysql

對于MariaDB,具有:


$ sudo systemctl stop mariadb

步驟3:在沒有權限檢查的情況下重新啟動數據庫服務器


如果您在運行MySQL和MariaDB時未加載有關用戶特權的信息,則它將允許您以root特權訪問數據庫命令行而無需提供密碼。這將允許您在不知道數據庫的情況下訪問數據庫。


為此,您需要使數據庫停止加載存儲用戶特權信息的授權表。因為這有一定的安全隱患,所以您還應該跳過聯網,以防止其他客戶端連接。


在不加載授權表或啟用網絡的情況下啟動數據庫:


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

該命令末尾的&符號將使此過程在后臺運行,因此您可以繼續(xù)使用終端。


現在,您可以以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';

請記住,此后要重新加載授權表。


無論哪種情況,您都應該看到確認命令已成功執(zhí)行的信息。


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 關注
  • 6944 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號