`

a beanFactoryReference already exists for key jbpmConfiguration

阅读更多

      项目采用了s2sh,在之前的基础上添加了对jBPM的支持,Action、Service、Dao等均由spring管理和维护,因此将jbpmConfiguration也交给spring,配置如下:

<!-- jBPM configuration --> 
<bean id="jbpmConfiguration" class="org.springmodules.workflow.jbpm31.LocalJbpmConfigurationFactoryBean"> 
    	<property name="configuration" value="classpath:jbpm.cfg.xml"/> 
</bean>

     

      重启tomcat,发现报异常,重要的异常信息如下

Caused by: java.lang.IllegalArgumentException: a beanFactoryReference already exists for key jbpmConfiguration

 

      于是,开始查找原因,经过一番努力,知道是产生了两个spring的beanFactory造成的,想到除了s2sh集成时初始化的一个ApplicationContext之外,由于需要曾自定义过一个ServletContextListener的实现类MyServletContextListener。果然对于ClassPathXmlApplicationContext,我使用ApplicationContext ctx= new ClassPathXmlApplicationContext("applicationContext.xml"); 重新创建了一个ApplicationContext,所以造成了上边的异常。

 

      接下来就是如何解决了,经过查找,终于知道使用WebApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(sce.getServletContext());

其中,sce对应ServletContextEvent的实例

 

      重启web容器,还是报异常,重点如下:

java.lang.IllegalStateException: No WebApplicationContext found: no ContextLoaderListener registered? 和java.lang.NullPointerException

 

      我明明配置了ContextLoaderListener ,可是却说我没有注册,这是何道理!但还是要从自身找问题的,经过一番Debug和查找后,终于发现是web.xml里配置listener的时候,顺序有问题。正确的顺序应该是ContextLoaderListener位于自定义的之前,而我配置的顺序正好相反;改为正确配置,于是一切恢复正常了。。。

 

接口:

org.springframework.context.ApplicationContext

org.springframework.web.context.WebApplicationContext

javax.servlet.ServletContextListener

类:

org.springframework.context.support.ClassPathXmlApplicationContext

org.springframework.web.context.support.WebApplicationContextUtils

javax.servlet.ServletContextEvent

1
1
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics