我正在使用spring 3.2和hibernate 4.2。我有 2 个 bean:数据源(c3p0)和带有属性文件(application.properties)的 sessionFactory(LocalSessionFactoryBean)。
当我使用带有显式用户名和密码的 java 配置定义数据源时,一切正常。在启动期间 c3p0 记录其配置。例如“属性”属性是:
properties -> {user=******, password=******}
这是确切的输出
但是当我在 xml 中(也使用用户和密码)而不是在 java 中定义相同的数据源时,应用程序的行为会有所不同。
“属性”属性显示
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 再次打印所有没有用户和密码的环境属性,但连接成功。好吧,好的:可以将池推送到会话工厂,但凭据必须在数据源中
发生什么了?我想要具有凭据和池配置的数据源以及具有休眠配置的休眠会话工厂。
以防万一。下面是我的配置:
<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 ds:
<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;
}