jsp部署问题:java.sql.SQLException: Access denied for user ‘root‘@‘localhost‘ 解决方案

博主在将使用JSP开发的小程序从开发环境迁移到朋友的生产环境时遇到了问题,常规的数据库连接检查、权限配置和编码匹配等排查方法并未奏效。通过查看Tomcat日志,发现在不同用户下编译的JSP缓存文件冲突导致错误。清理工作目录下的缓存文件后,问题得到解决,小程序恢复正常运行。这次经历提醒我们在部署时要注意跨环境的用户权限和编译文件处理。

踩坑经历:希望可以很快的帮你定位问题(用jsp虽然简单、直观、快捷,但是遇到这类配置上的问题就比较头疼,所以更多人才会转向springboot、docker部署,不过应用实在太小,没必要占用朋友的服务器空间,所以才用了古老的jsp,一小时搞定需求)

上一篇给小区管理人员提供的小程序,在开发环境运行正常,搬到借用朋友的生产环境时报上面的错误,根据历史经验,先是从一下三个方面进行查找:

一、数据库连接字符串有没有写错,有没有多余空格之类的

二、数据库的权限是否赋权到位,localhost和远程%是否根据需要配置

三、数据库编码以及连接串中是否匹配

一般情况下,查完上面三个就可以解决了,但是这次竟然还是没有,这时只有查tomcat运行日志了(日志文件在tomcat目录下的logs文件夹中,本次查看的catalina.yyyy-mm-dd.log文件),发现有个“org.apache.jasper.compiler.Compiler.removeGeneratedClassFiles 未能删除生成的类文件”错误,到这里问题就找到了,原来是因为我把开发环境的tomcat9直接拷贝到生产环境并手动开启服务,它的编译目录中缓存文件我并没有事先清除,由于jsp运行前是需要先编译的,两个系统不同的用户进行编译就发生了这个问题,进入tomcat所在目录下的/work/Catalina/localhost,把里面的缓存文件全部删了,再运行代码,恢复正常。

java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES) 是一个常见的数据库连接错误,表示用户'root'在本地主机上使用了错误的密码进行连接。 解决这个问题的方法有以下几种: 1. 确保用户名和密码正确:首先,确保你使用的用户名和密码是正确的。检查你的数据库配置文件或者数据库管理工具中的用户名和密码是否与你尝试连接的数据库一致。 2. 检查数据库权限:如果用户名和密码是正确的,但仍然无法连接数据库,可能是因为该用户没有足够的权限访问数据库。请确保该用户具有正确的权限,包括连接数据库和执行所需的操作。 3. 检查数据库连接字符串:检查你的数据库连接字符串是否正确。确保连接字符串中的用户名、密码和数据库名称都是正确的。 4. 检查数据库服务器配置:如果以上方法都没有解决问题,可能是因为数据库服务器的配置有问题。请检查数据库服务器的配置文件,确保允许远程连接,并且没有其他限制。 5. 检查防火墙设置:有时候,防火墙设置可能会阻止数据库连接。请确保你的防火墙允许数据库连接。 6. 重置密码:如果你确信用户名和密码是正确的,但仍然无法连接数据库,可以尝试重置密码。使用数据库管理工具或者命令行工具重置密码,并更新你的应用程序中的连接信息。 这些方法应该能够帮助你解决java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)错误。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数智前沿

您的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值