我在過去幾週一直在使用Spring Framework 3.0,並且給我留下了深刻的印象。這是我第一個使用Java的項目。我的主要問題是我找不到一種方法讓最終用戶在Web應用程序內管理自己的數據庫連接。我正在進行的項目將安裝在客戶端的計算機上,他們將提供所有連接信息。此時,每當數據源不可用,我得到一個錯誤,我不知道如何處理:如何在Spring MVC Web應用程序中管理數據庫設置?
java.sql.SQLException: Network error IOException: Connection refused
我試圖延遲加載XML配置的數據源,但它仍然在加載時應用的預期間啓動 - 實例化單身人士階段。
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"
lazy-init="true">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url"
value="${jdbc.urlprefix}://${jdbc.server}:${jdbc.port}/${jdbc.database}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="initialSize" value="2" />
<property name="maxActive" value="5" />
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"
lazy-init="true">
<property name="dataSource" ref="dataSource" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">false</prop>
</props>
</property>
<property name="annotatedClasses">
<list>
....
</list>
</property>
</bean>
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager"
lazy-init="true">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
我希望當數據庫不可用或不正確的配置我可以將用戶重定向到不依賴於數據庫連接,這樣的設置可以管理上的頁面。我只是不確定在IoC容器期望從一開始就正確配置DataSource時如何實現這一點。
預先感謝您!