第一次写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,原理相同。