【踩坑系列】sm整合,配置dataSource时value=“${username}“获取的是系统用户名

第一次写ssm整合demo,最后测试的时候死活连接不上数据库,查看错误信息时发现:
Error querying database. Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is java.sql.SQLException: Access denied for user 'Alchemist'@'localhost' (using password: YES)
这…用户名怎么是我windows的用户名啊?应该是root才对啊,此时相关的配置文件如下:

<context:property-placeholder location="classpath:db.properties"/>
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
    </bean>

db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8
username=root
password=root

db.properties在mybatis的全局配置文件中使用正常,用${username}可以取到正确的值root,所以在配置dataSource的时候也直接使用了这个文件没有改动。问题发生后我将username改为username1,问题解决。只要避免出现${username}即可。后续我以“${username}取到了系统用户名”为关键词才查找到类似错误的解决方案,普遍是添加前缀,如jdbc.username,原理相同。

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页