4

我有一个使用 mojarra 2.1.17 发行版开发的 JSF 2.1 Web 应用程序,它在 JBoss 6.1 容器上运行时遇到任何问题:现在我必须更改应用程序服务器,我必须使用随 MyFaces JSF 2 发行版诞生的 websphere AS 8.5。我正在尝试部署和启动我的 webapp 忽略 MyFaces 并使用 Mojarra,将我的 EAR 配置为 IBM 官方指南所示,配置包含 mojarra dist 的共享库,将其链接到专门为我的 server1 WAS 8.5 实例创建的新类加载器。它根本不起作用,当我部署我的 web 应用程序时,当 WAS 尝试启动应用程序时,我得到了这个堆栈跟踪:

com.ibm.ws.exception.RuntimeWarning: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: Failed to load webapp: null
        at com.ibm.ws.webcontainer.component.WebContainerImpl.install(WebContainerImpl.java:432)
        at com.ibm.ws.webcontainer.component.WebContainerImpl.start(WebContainerImpl.java:718)
        at com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:1175)
        at com.ibm.ws.runtime.component.DeployedApplicationImpl.fireDeployedObjectStart(DeployedApplicationImpl.java:1370)
        at com.ibm.ws.runtime.component.DeployedModuleImpl.start(DeployedModuleImpl.java:639)
        at com.ibm.ws.runtime.component.DeployedApplicationImpl.start(DeployedApplicationImpl.java:968)
        at com.ibm.ws.runtime.component.ApplicationMgrImpl.startApplication(ApplicationMgrImpl.java:774)
        at com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:2182)
        at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:445)
        at com.ibm.ws.runtime.component.CompositionUnitImpl.start(CompositionUnitImpl.java:123)
        at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:388)
        at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.access$500(CompositionUnitMgrImpl.java:116)
        at com.ibm.ws.runtime.component.CompositionUnitMgrImpl$CUInitializer.run(CompositionUnitMgrImpl.java:994)
        at com.ibm.wsspi.runtime.component.WsComponentImpl$_AsynchInitializer.run(WsComponentImpl.java:502)
        at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1862)
    Caused by: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: Failed to load webapp: null
        at com.ibm.ws.webcontainer.WSWebContainer.addWebApp(WSWebContainer.java:759)
        at com.ibm.ws.webcontainer.WSWebContainer.addWebApplication(WSWebContainer.java:634)
        at com.ibm.ws.webcontainer.component.WebContainerImpl.install(WebContainerImpl.java:426)
        ... 14 more
    Caused by: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: null
        at com.ibm.ws.webcontainer.VirtualHostImpl.addWebApplication(VirtualHostImpl.java:176)
        at com.ibm.ws.webcontainer.WSWebContainer.addWebApp(WSWebContainer.java:749)
        ... 16 more
    Caused by: java.lang.NullPointerException
        at com.sun.faces.config.InitFacesContext.cleanupInitMaps(InitFacesContext.java:283)
        at com.sun.faces.config.InitFacesContext.<init>(InitFacesContext.java:107)
        at com.sun.faces.config.FacesInitializer.onStartup(FacesInitializer.java:115)
        at com.ibm.ws.webcontainer.webapp.WebAppImpl.initializeServletContainerInitializers(WebAppImpl.java:613)
        at com.ibm.ws.webcontainer.webapp.WebAppImpl.initialize(WebAppImpl.java:409)
        at com.ibm.ws.webcontainer.webapp.WebGroupImpl.addWebApplication(WebGroupImpl.java:88)
        at com.ibm.ws.webcontainer.VirtualHostImpl.addWebApplication(VirtualHostImpl.java:169)
        ... 17 more

我也调试了 mojarra dist 的 cleanupInitMaps() 方法,我看到它试图从 FacesContext 中获取两个 Map 类型的变量,称为threadInitContextinitContextServletContext但得到 null:

Field threadMap = FacesContext.class.getDeclaredField("threadInitContext");
and 
Field initContextMap = FacesContext.class.getDeclaredField("initContextServletContext");

这是如何引起的,我该如何解决?

4

2 回答 2

2

好的,我解决了!!首先,我将服务器实例的类加载器设置为 PARENT_LAST + 重新启动。然后我按照以下步骤操作:1)将 Mojarra lib 放入简单的共享库中;2)在内部部署带有jsf web模块的ear,在从控制台启动应用程序之前,我将共享库链接到它以及ear内的所有模块;3)我将应用程序类加载器设置为PARENT_LAST;4)启动应用程序,它的工作原理!

就这样 !!

于 2013-09-26T06:16:39.857 回答
0

我遇到了同样的问题。在我的情况下,问题是通过从工件中删除javax.faces依赖来解决的。.war这似乎是WS 的实现和我文件javax.faces中的依赖之间的冲突。.war如果您使用 maven,那么您可以为您的javax.faces依赖项设置范围,如下所示:

    <dependency>
        <groupId>org.glassfish</groupId>
        <artifactId>javax.faces</artifactId>
        <version>2.2.13</version>
        <scope>provided</scope>
    </dependency>

另请参阅:com.sun.faces.config.InitFacesContext.cleanupInitMaps 处的 Nullpointer 异常

于 2017-10-13T07:15:32.850 回答