3

我有一个可以使用两种不同持久性 API 的 Spring 应用程序:

  • 春季数据 JPA
  • 春季数据 Neo4j

使用 Spring Data JPA 时,我需要在“web.xml”中声明“OpenEntityManagerInViewFilter”来进行延迟加载:

<filter>
    <filter-name>OpenEntityManagerInViewFilter</filter-name>
    <filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>OpenEntityManagerInViewFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

问题是我在使用 Spring Data Neo4j 时无法启用此过滤器。保持启用会导致以下运行时错误:

No qualifying bean of type [javax.persistence.EntityManagerFactory] is defined

我想选择与 Spring 配置文件一起使用的数据库(例如spring.profiles.active=relational-databasespring.profiles.active=graph-database)。

问题:当配置文件是“关系数据库”时如何启用“OpenEntityManagerInViewFilter”,当配置文件是“图形数据库”时禁用它?

谢谢!

相关问题:

4

1 回答 1

5

好的,我解决了这个问题。我的新“web.xml”使用DelegatingFilterProxy而不是org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter

<filter>
    <filter-name>toggleOpenEntityManagerInViewFilter</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
    <filter-name>toggleOpenEntityManagerInViewFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

然后在我的 ApplicationContext 中,我创建了一个名为“toggleOpenEntityManagerInViewFilter”的 bean(这是filter-name值)。诀窍是根据 Spring 配置文件实例化不同的类:

<beans profile="graph-database">
    <bean id="toggleOpenEntityManagerInViewFilter" class="my.project.dal.utils.spring.DoNothingFilter"/>
</beans>
<beans profile="relational-database">
    <bean id="toggleOpenEntityManagerInViewFilter" class="org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter"/>
</beans>

my.project.dal.utils.spring.DoNothingFilter定义为:

public class DoNothingFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        filterChain.doFilter(servletRequest, servletResponse);
    }

    @Override
    public void destroy() {
    }
}

这似乎有效。

于 2015-06-12T15:11:11.263 回答