java - c3p0 和 hibernate 用户/密码覆盖

标签 java spring hibernate connection-pooling c3p0

我正在使用 spring 3.2 和 hibernate 4.2。我有 2 个 bean:数据源 (c3p0) 和带有属性文件 (application.properties) 的 sessionFactory (LocalSessionFactoryBean)。

当我使用带有显式用户名和密码的 java 配置定义数据源时,一切正常。在启动期间,c3p0 会记录其配置。例如“属性”属性是:

properties -> {user=******, password=******}

这是准确的输出

但是当我在 xml 中(也使用用户和密码)而不是在 java 中定义相同的数据源时,应用程序的行为会有所不同。

'properties'属性显示

properties -> {java.runtime.name=xxx, line.separator=xxx, maven.home=xxx, ...}

和所有环境变量,但与用户或密码无关。它拒绝连接到数据库:

java.sql.SQLException: ORA-01017: invalid username/password; logon denied

但是在 application.properties 中我添加:

hibernate.connection.username=xxx
hibernate.connection.password=xxx

c3p0 再次打印所有没有用户和密码的环境属性,但连接成功。好吧,可以:可以将池推送到 session 工厂,但凭据必须在数据源中

这是怎么回事?我想要具有凭据和池配置的数据源以及具有 hibernate 配置的 hibernate session 工厂。

以防万一。下面是我的配置:

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="xxx.model" />
        <property name="hibernateProperties">
            <util:properties location="classpath:/spring/application.properties" />
        </property>
    </bean>

xml 文件:

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <property name="driverClass" value="oracle.jdbc.driver.OracleDriver"/>
        <property name="user" value="xxx"/>
        <property name="password" value="xxx"/>
        <property name="jdbcUrl" value="xxx"/>
    </bean>

和java ds:

@Bean
public DataSource dataSource() throws PropertyVetoException {
    ComboPooledDataSource ds = new ComboPooledDataSource();
    ds.setDriverClass("oracle.jdbc.driver.OracleDriver");
    ds.setUser("xxx");
    ds.setPassword("xxx");
    ds.setJdbcUrl("xxx");
    return ds;
}

最佳答案

所以这很奇怪。

我的猜测是这样的。 c3p0 的 DriverManagerDataSource 有一个名为“properties”的属性,类型为 java.util.Properties。

在某个地方,您的中间件世界中的某些东西被配置为自动将此类属性设置为 System.properties。我觉得这是一件坏事,但这似乎是正在发生的事情。最好的办法是关闭此行为。这不是 c3p0 的事情,但除此之外,我不确定你应该看哪里。

一个建议是尝试在您的 XML 中显式设置 properties 属性 [yuk]。也许这会阻止它默认为系统属性。参见例如here了解如何设置属性类型的属性。 properties 属性应该包含一个名为“user”的键和一个名为“password”的键(并且不需要在这些属性之外设置用户和密码)。像这样的东西:

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
    <property name="driverClass" value="oracle.jdbc.driver.OracleDriver"/>
    <property name="jdbcUrl" value="xxx"/>
    <property name ="properties">
       <props>
          <prop key="user">xxx</prop>
          <prop key="paswords">xxx</prop>
       </props>
    </property>
</bean>

祝你好运!

关于java - c3p0 和 hibernate 用户/密码覆盖,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15785705/

相关文章:

java - 处理复制/重复调整大小问题

java - Windows 7 防火墙 : Modify group items from command line

java - 无法执行 jar 文件 : "no main manifest attribute"

java - StoredProcedureItemReader 和 JdbcCursorItemReader 的游标数据保留在 java 堆内存中还是数据库中

java - 对于 JPA 元模型生成的类,Maven "clean install site"失败

java - mysql jdbc与ssl连接

java - 没有注册仪器,运行单元测试时出错

java - Spring Security + CAS SSO 身份验证管理器

java - 在 spring boot yml 文件中添加自定义 logback 日志模式

java - package-info.java + Hibernate 注解@TypeDefs + Maven