mysql - playframework 应用程序无法连接到数据库“用户'root'@'localhost'的访问被拒绝(使用密码:是)”
问题描述
我有正确的用户名和密码,并且在application.conf
. 我知道这一点是因为我没有更改它,application.conf
并且它在几个小时前就起作用了。改变的是我将 Ubuntu 从 14.04 LTS 升级到 20.04 LTS(在其他 LTS 版本中采取了几个步骤)。这也将 MySQL 从 5.5.43 升级到了 8.0.26。我最初没有升级 mysql-connector,但是在我的应用程序无法连接到数据库后,我尝试将连接器从 5.1.18 升级到 8.0.26。
我可以直接从命令行使用mysql
相同的用户名和密码登录 MySQL application.conf
,所以我知道用户名和密码仍然有效。
这是我从 Play Framework 应用程序中得到的异常:
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver has automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
Configuration error: Configuration error[Cannot connect to database [default]]
at play.api.Configuration$.play$api$Configuration$$configError(Configuration.scala:94)
at play.api.Configuration.reportError(Configuration.scala:743)
at play.api.db.BoneCPPlugin$$anonfun$onStart$1.apply(DB.scala:247)
at play.api.db.BoneCPPlugin$$anonfun$onStart$1.apply(DB.scala:238)
at scala.collection.immutable.List.map(List.scala:273)
at play.api.db.BoneCPPlugin.onStart(DB.scala:238)
at play.api.Play$$anonfun$start$1$$anonfun$apply$mcV$sp$1.apply(Play.scala:91)
at play.api.Play$$anonfun$start$1$$anonfun$apply$mcV$sp$1.apply(Play.scala:91)
at scala.collection.immutable.List.foreach(List.scala:381)
at play.api.Play$$anonfun$start$1.apply$mcV$sp(Play.scala:91)
at play.api.Play$$anonfun$start$1.apply(Play.scala:91)
at play.api.Play$$anonfun$start$1.apply(Play.scala:91)
at play.utils.Threads$.withContextClassLoader(Threads.scala:21)
at play.api.Play$.start(Play.scala:90)
at play.core.StaticApplication.<init>(ApplicationProvider.scala:55)
at play.core.server.NettyServer$.createServer(NettyServer.scala:253)
at play.core.server.NettyServer$$anonfun$main$3.apply(NettyServer.scala:289)
at play.core.server.NettyServer$$anonfun$main$3.apply(NettyServer.scala:284)
at scala.Option.map(Option.scala:146)
at play.core.server.NettyServer$.main(NettyServer.scala:284)
at play.core.server.NettyServer.main(NettyServer.scala)
Caused by: java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:828)
at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:448)
at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241)
at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:198)
at java.sql.DriverManager.getConnection(DriverManager.java:664)
at java.sql.DriverManager.getConnection(DriverManager.java:247)
at com.jolbox.bonecp.BoneCP.obtainRawInternalConnection(BoneCP.java:363)
at com.jolbox.bonecp.BoneCP.<init>(BoneCP.java:416)
at com.jolbox.bonecp.BoneCPDataSource.getConnection(BoneCPDataSource.java:120)
at play.api.db.BoneCPPlugin$$anonfun$onStart$1.apply(DB.scala:240)
... 18 more
这是从命令行成功登录的:
$ mysql -u root -p
Enter password:
Welcome to the MySQL monitor. Commands end with; or \g.
Your MySQL connection id is 31
Server version: 8.0.26-0ubuntu0.20.04.3 (Ubuntu)
Copyright (c) 2000, 2021, Oracle and/or its affiliates.
Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
application.conf
有以下几行:
db.default.driver=com.mysql.jdbc.Driver
db.default.url="jdbc:mysql://localhost/mydatabase"
db.default.user=root
db.default.pass="password"
我有 Play Framework 2.3.9 和 Java 1.8.0_51(在升级过程中都没有改变)。
解决方案
从配置中的密码中删除引号
我检查了规范,你是对的引号无关紧要。
推荐阅读
- python-3.x - pip 如何告诉 Python 如何导入 C 扩展
- vba - 字典和一个工作簿中每个键的项目总和并写入另一个工作簿
- flurl - Flurl 发布数据
- macos - 使用 AppleScript 选择包含字符串的下拉菜单项
- flutter - 如何删除 Firestore 中的数组元素?
- c# - 我无法在 Visual Studio 2k17 中看到 AssemblyInfo.cs 文件
- javascript - 为什么在我的项目中没有将异步定义为它自己的功能?
- python - 颜色控制台使用 stdiomask 不给出类型错误
- c# - 如何在 ASP.NET MVC 应用程序中创建计划?
- python - 在 python 3.7 上打印图像