spring 3.2 と hibernate 4.2 を使用しています。プロパティファイル(application.properties)を持つデータソース(c3p0)とセッションファクトリー(LocalSessionFactoryBean)の2つのBeanがあります。
明示的なユーザー名とパスワードを使用してJava構成を使用してデータソースを定義すると、すべてうまくいきます。起動時に c3p0 はその構成をログに記録します。たとえば、「プロパティ」プロパティは次のとおりです。
properties -> {user=******, password=******}
それが正確な出力です
しかし、同じデータソースを Java ではなく xml (ユーザーとパスワードも含む) で定義すると、アプリケーションの動作が異なります。
「プロパティ」プロパティが表示されます
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;
}