zoukankan      html  css  js  c++  java
  • Access denied for user 'Administrator'@'localhost' (using password: YES)

    在Spring容器中通过配置 <context:property-placeholder location="classpath:/jdbc.properties"/> 调用properties数据源配置文件时出现 Access denied for user 'Administrator'@'localhost' (using password: YES) 错误!!!!

    Properties配置(C3p0数据源):

    dirver=com.mysql.jdbc.Driver
    jdbcUrl=jdbc:mysql://localhost:3306/mydb1
    username=root
    password=admin

    Spring基本配置(完成注入):

    <context:property-placeholder location="classpath:/jdbc.properties"/>
    
    <bean id="datasouce" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass"  value="${dirver}"/>
        <property name="jdbcUrl" value="${jdbcUrl}"/>
        <property name="user" value="${username}"/>
        <property name="password" value="${password}"/>
    </bean>

    ---- 在获取数据源中的连接时出现上述的错误。

     错误原因:

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

    解决方案:

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

      方案二:在Spring配置文件中修改成:<context:property-placeholder location="classpath:/jdbc.properties" system-properties-mode="FALLBACK / NEVER"/>   

          添加一个system-properties-mode属性

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

                  NEVER      --- 不覆盖

                  OVERRIDE  --- 覆盖

  • 相关阅读:
    MySQL中文显示乱码
    mysql 存储引擎 InnoDB 与 MyISAM 的区别和选择
    mysql 分表的3种方法
    mysql 清空或删除表数据后,控制表自增列值的方法
    MySQL 下优化SQL语句的一些经验
    mysql 常用命令
    MySQL获得指定数据表中auto_increment自增id值的方法及实例
    SQL Server Alwayson创建代理作业注意事项
    LinkedList子类与Queue接口
    List接口
  • 原文地址:https://www.cnblogs.com/tongxuping/p/7081656.html
Copyright © 2011-2022 走看看