Spring使用中 Access denied for user 'Administrator'@'localhost' (using password: YES)

Access denied for user xxx 一个问题找原因找了很久,最后看到这个博客终于找到了问题所在
https://www.cnblogs.com/tongxuping/p/7081656.html
在配置中使用的用户名为username
并且注入时使用

<property name="user" value="${username}"/>

错误原因:

  在系统中也有个username属性,这时系统变量覆盖了Properties中的值,这时取得username的值为系统的用户名Administrator,密码为properties中的password去查询数据库,此时用户名名和密码并不匹配就会报错。在Spring完成注入时是用 “${..}” 方式获取值完成注入的。而通过这种表达式也能直接获取到JVM系统属性……….
  解决方案:

  方案一:将properties文件中的username换成user或其他就字符串就可以成功获取连接访问数据库。建议:username时敏感词汇,为了安全起见还是尽量不要使用username。

  方案二:在Spring配置文件中修改成:
  
  或
  

      添加一个system-properties-mode属性

      该属性有三个值:FALLBACK  — 默认值,不存在时覆盖

              NEVER    — 不覆盖

              OVERRIDE  — 覆盖

你可能感兴趣的:(Spring使用中 Access denied for user 'Administrator'@'localhost' (using password: YES))