spring的xml配置文件中获取jdbc.properties乱码导致连接数据库失败

本文记录了一次使用Spring JDBC连接数据库时遇到的奇怪问题:由于Spring将属性文件中的用户名误解析为系统的用户名而导致连接失败。文章详细介绍了问题的排查过程及解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 今天遇到一个奇葩的问题,获取jdbc.properties中配置好的属性连接数据库竟然失败了。

不多说,直接上代码。

Exception in thread "main" org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is java.sql.SQLException: Access denied for user '飞飞'@'localhost' (using password: YES)

经过我检查,发现错误就出现在username属性上,spring竟然把${username)的值解析为我电脑用户名的值了,可想而知,肯定连不上了。只要把jdbc.properties和xml的username改成name就行。

至于我为什么不用${jdbc.username}这种写法呢,那样的话是不是不会出现这种错误了呀。没错,直接这样写是不会出现那种奇葩的问题,可是,会出现这种问题啊。。

Invalid bean definition with name 'dataSource' defined in class path resource [applicationContext.xml]:

Could not resolve placeholder 'jdbc.driverClassName' in value "${jdbc.driverClassName}";

  我用的原生的spring的jdbc,我怀疑spring没有把${jdbc.username}解析出来。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值