我在过去几周一直在使用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时如何实现这一点。
预先感谢您!