最近在使用wabacus框架开发项目,确实非常方便和高效,但有的非常复杂业务还需要用传统的ssh2进行开发,这个时候就想两个共用一个数据源,即都用ssh2配置的数据源,经过请教作者,终于实现了,方法大致如下:?
1:创建一个类MyContext.java,如下
class="java" name="code">public class MyContext implements ApplicationContextAware { private static ApplicationContext context;// 声明一个静态变量保存 @Override public void setApplicationContext(ApplicationContext context) throws BeansException { // TODO Auto-generated method stub this.context = context; } public static ApplicationContext getContext() { return context; } }
?2:在applicationContext.xml里面注入该类,
? <bean class="com.util.MyContext"></bean>
?? 这样就可以在类里面使用applicationContext提供的bean啦。
创建SpringDataSource.java,该类为wabacus提供数据源(调用的是applicationContext里面的数据源)如下:
public class SpringDataSource extends AbsDataSource { private static Logger logger = Logger.getLogger(SpringDataSource.class); private DataSource ds; public SpringDataSource(){ this.ds = (DataSource) MyContext.getContext().getBean ("dataSource"); System.out.println("########"+ this.ds.toString()); } @Override public Connection getConnection() { try { logger.debug("从数据源" + this.getName() + "获取数据库连接"); return this.ds.getConnection(); } catch (SQLException e) { throw new WabacusRuntimeException("获取" + this.getName() + "数据源的数据库连接失败", e); } } @Override public DataSource getDataSource() { return this.ds; } }
?4:在wabacus的配置文件wabacus.cfg.xml 中就可以这样配置来获取数据源啦,如下:
<datasources default="ds_mysql"> <datasource name="ds_mysql" type="com.wabacus.SpringDataSource" dbtype="com.wabacus.config.database.type.MySql"> <property name="driver">driver</property> </datasource> </datasources>
?