35

我正在使用这个:

  • 雄猫 7.0
  • JSF 2.0
  • JRE 7

但是在尝试运行我的应用程序时,出现以下异常:

java.lang.IllegalStateException: Could not find backup for factory javax.faces.application.ApplicationFactory. 
    at javax.faces.FactoryFinder$FactoryManager.getFactory(FactoryFinder.java:1011)
    at javax.faces.FactoryFinder.getFactory(FactoryFinder.java:343)
    at org.apache.myfaces.context.servlet.FacesContextImplBase.getApplication(FacesContextImplBase.java:159)
    at org.apache.myfaces.context.servlet.FacesContextImplBase.getELContext(FacesContextImplBase.java:210)
    at javax.faces.component.UIViewRoot.setLocale(UIViewRoot.java:1463)
    at org.apache.myfaces.webapp.AbstractFacesInitializer._createFacesContext(AbstractFacesInitializer.java:477)
    at org.apache.myfaces.webapp.AbstractFacesInitializer.initStartupFacesContext(AbstractFacesInitializer.java:449)
    at org.apache.myfaces.webapp.StartupServletContextListener.contextInitialized(StartupServletContextListener.java:113)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4797)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5291)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
    at java.util.concurrent.FutureTask.run(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)

任何想法为什么?

谢谢,

4

5 回答 5

35

如果您的 webapp 的运行时类路径被多个 JSF 实现/版本污染,则可能会发生这种情况。堆栈跟踪中的org.apache.myfaces条目表明您正在使用 MyFaces。因此,此问题表明您在 webapp 的运行时类路径中有另一个 JSF 实现,例如 Mojarra,它与它发生冲突。jsf-api.jar它可以通过、 或jsf-impl.jar、 或识别javax.faces.jar。如果您删除所有这些,那么这个问题应该会消失。

或者,如果您实际上打算使用 Mojarra 而不是 MyFaces(您没有在问题的任何地方明确说明意图的 JSF impl/version,但您只是在“JSF 2.0”中一般性地说明了 JSF 规范,所以也许您实际上有不知道你在做什么),那么你应该myfaces-*.jar从你的 webapp 中删除文件。

也可以看看:

于 2013-09-19T14:58:26.837 回答
4

作为 BalusC 的回答的补充,我最近在尝试使用 Spring Boot 应用程序运行独立 JAR 时遇到此错误,该应用程序将 JSF 作为前端并使用 Spring 管理的 bean。将包装从 JAR 切换到 WAR 解决了这个问题。

于 2015-11-06T16:20:37.220 回答
4

对我来说 {Tomcat 8, JSF 2.2, JRE 8},以下步骤有效:

  1. 下载 JSTL jars API && IMPL 并将其放在您的 Tomcat 库中。

  2. 由于最近在项目方面配置中直接从 eclipse 下载 Majorra 是不可能的;“Zip File is empty Exception”,手动下载 jsf-api.jar 和 jsf-impl.jar 并将它们包含在添加到构建路径的新用户库中(仅一次!)。

这是我的 web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
  <display-name>TestJSF</display-name>
  <welcome-file-list>
    <welcome-file>index.xhtml</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>Faces Servlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Faces Servlet</servlet-name>
    <url-pattern>/faces/*</url-pattern>
  </servlet-mapping>
  <context-param>
    <description>State saving method: 'client' or 'server' (=default). See JSF Specification 2.5.2</description>
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>client</param-value>
  </context-param>
  <context-param>
    <param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name>
    <param-value>resources.application</param-value>
  </context-param>
  <listener>
    <listener-class>com.sun.faces.config.ConfigureListener</listener-class>
  </listener>
</web-app>
于 2018-11-22T13:16:19.513 回答
0

除了已经说过的,我在导入第三方项目时遇到了这个问题,原因是在 pom.xml 中定义了两个配置文件,一个用于 My Faces,另一个用于 Mojarra。如果是这种情况,您只需使用 maven -P 或在项目属性的 Maven 部分中选择其中之一,指示要使用的配置文件。

于 2021-05-20T10:53:18.667 回答
0

在我的情况下,这个异常是由于在 Tomcat 8.0 下运行 Mojarra 2.2.x的存在而com.sun.faces.config.ConfigureListener在webapp 关闭时引起的。web.xml本答案中所述,这会导致 Tomcat 两次注册该侦听器(自动和通过web.xml条目),因此,除其他外,它的contextDestroyed方法被执行两次,第二次产生所描述的异常(很可能是因为 JSF 是已经被第一个监听器注册关闭)。

在我的情况下,我没有类路径冲突:只有一个版本的 Mojarra (2.2.6),没有 MyFaces。

于 2021-09-15T09:22:38.047 回答