Spring-Hibernate多用户Web应用程序中的DAO范围是什么?

3

我之前看到了这个问题,但是没有从中得到很多信息,所以我会更加具体地描述我的问题。
在我的多用户Web应用程序中,我有一个BaseDAO类,它长这样:

public abstract class BaseDAO<GenType>
{
private HibernateOperations hibernateTemplate;

protected BaseDAO() {}
protected HibernateOperations getHibernateTemplate() {
    return hibernateTemplate;
}
public void setHibernateTemplate(HibernateOperations hibernateTemplate) {
    this.hibernateTemplate = hibernateTemplate;
}
protected void initialize(final Object proxy) throws DataAccessException {
    hibernateTemplate.initialize(proxy);
}
public GenType merge(GenType entity) throws DataAccessException {
    return (GenType)hibernateTemplate.merge(entity);
}
protected void persist(GenType entity) throws DataAccessException {
    hibernateTemplate.persist(entity);
}
public void refresh(GenType entity) throws DataAccessException {
    hibernateTemplate.refresh(entity);
}
public void save(GenType entity) throws DataAccessException {
    hibernateTemplate.save(entity);
}
public void saveOrUpdate(GenType entity) throws DataAccessException {
    hibernateTemplate.saveOrUpdate(entity);
}
public void update(GenType entity) throws DataAccessException {
    hibernateTemplate.update(entity);
}
public void delete(GenType entity) throws DataAccessException {
    hibernateTemplate.delete(entity);
}
protected void deleteAll(Collection<GenType> entities) throws DataAccessException {
    hibernateTemplate.deleteAll(entities);
}
protected GenType get(Class<GenType> entityClass, Serializable id) throws DataAccessException {
    return (GenType)hibernateTemplate.get(entityClass, id);
}
}

这基本上是对HibernateTemplate的封装。我的所有其他DAO都继承了这个类并实现了适当的接口,这些接口包含一些额外的方法(比如getBySomeAttribute())。因此,这些DAOs仅具有方法。此外,我还有一个service层来封装DAOs。也就是说,一个服务类可以持有多个DAOs,并且从服务层调用的方法会被spring-AOP截取以进行自动提交/回滚(事务划分)。例如:

public class ModelDAO extends BaseDAO<Model> implements IModelDAO
{
    @Override
    public Model getNew() {
        return new Model();
    }

    @Override
    public List<Model> getBySomeAttr() {
        DetachedCriteria criteria;
        // define some criteria
        return getHibernateTemplate().findByCriteria(criteria);
    }
}

...

public class ModelService
{
    private ModelDAO modelDAO;
    private ElementDAO elementDAO;
    // GET/SET for model and user DAO

    public void doSomethingWithModel() {

        modelDAO.doSomething();
        elementDAO.doSomethingElse();
    }
}

配置如下:

<bean id="hibernateTemplate2" class="org.springframework.orm.hibernate3.HibernateTemplate">
    <property name="sessionFactory" ref="sessionFactory2" />
    <property name="maxResults" value="3000" />
</bean>

<!-- DAO -->
<bean id="baseDAO" abstract="true" 
    class="org.irvas.backend.dao_implement.BaseDAO" scope="session">
    <property name="hibernateTemplate" ref="hibernateTemplate2" />
</bean>
<bean id="modelDAO" 
    class="org.irvas.backend.dao_implement.ModelDAOImplement" 
    parent="baseDAO" scope="session">
</bean>
<bean id="elementDAO" 
    class="org.irvas.backend.dao_implement.ElementDAOImplement" 
    parent="baseDAO" scope="session">
</bean>

<!-- Service -->
<bean id="modelService" 
    class="org.irvas.backend.service_implement.ModelServiceImplement" scope="session">
    <property name="modelDAO" ref="modelDAO" />
    <property name="elementDAO" ref="elementDAO" />
</bean>
<bean id="elementService" 
    class="org.irvas.backend.service_implement.ElementServiceImplement" scope="session">
    <property name="elementDAO" ref="elementDAO" />
</bean>

所以,我想知道如何为多用户目的范围DAO/Service bean?我将Service bean注入GUI的原型控制器中。
当我使用此配置(scope="session")时,会出现以下错误:
“Error creating bean with name 'modelService': java.lang.IllegalArgumentException setAttribute: Non-serializable attribute: modelDAO”
我认为这是由Tomcat的StandardSession.setAttribute()引起的。从这里我可以得出结论,我的DAO应该实现Serializable,更让我困惑的是,我看到完全相同的代码,没有实现Serializable也能正常工作...
如果有人能启发我这里到底发生了什么,以及如何为这种情况范围DAO和Services,我会非常感激...
1个回答

3

没有必要将你的DAO设置为会话作用域。

虽然Hibernate session具有状态,但在正确配置的事务管理下,它的状态绑定到事务(即在同一事务中调用的不同DAO方法共享同一会话,而从不同事务调用的相同方法则使用不同会话)。

因此,你的DAO实际上是无状态的,并且应该是单例作用域(即默认作用域)。


嗯,我也是这么想的,但我需要一些确认。谢谢。 - Less

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接