2010-09-27 42 views
1

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

预先感谢您!

回答

0

这是一个黑客....使用内存数据库作为默认配置。

如果系统启动时,它仍然是默认的数据库,那么你知道发生了错误。

1

Spring的AbstractRoutingDataSource是一个中介数据源,它将getConnection()调用路由到另一个目标DataSource,确定了运行时间。将缺省目标数据源设置为内存数据库,以便在加载应用程序上下文时有数据库可以连接到该数据库。当用户提供连接信息时,您的AbstractRoutingDataSource子类可以路由到使用连接信息配置的另一个数据源。

相关问题