使用 Myfaces 2.3 在 WAS 8.5.5.16 中遇到问题 'An error occured while initializing MyFaces'

Facing issues 'An error occured while initializing MyFaces' in WAS 8.5.5.16 with Myfaces 2.3

我正在尝试使用 Java 8 在 WAS 8.5.5.16 中部署 Myfaces 2.3 基础应用程序,但遇到下面提到的错误。

0000005c AbstractFaces E 初始化 MyFaces 时出错:Class com.ibm.ws.jsf.config.annotation.WASMyFacesAnnotationProvider 不是 org.apache.myfaces.spi.AnnotationProvider java.lang.IllegalArgumentException: Class com.ibm.ws.jsf.config.annotation.WASMyFacesAnnotationProvider 没有 org.apache.myfaces.spi.AnnotationProvider 在 org.apache.myfaces.shared.util.ClassUtils.buildApplicationObject(ClassUtils.java:567) 在 org.apache.myfaces.shared.util.ClassUtils.buildApplicationObject(ClassUtils.java:534) 在 org.apache.myfaces.spi.impl.DefaultAnnotationProviderFactory.resolveAnnotationProviderFromService(DefaultAnnotationProviderFactory.java:138) 在 org.apache.myfaces.spi.impl.DefaultAnnotationProviderFactory.createAnnotationProvider(DefaultAnnotationProviderFactory.java:93) 在 org.apache.myfaces.spi.impl.DefaultAnnotationProviderFactory.getAnnotationProvider(DefaultAnnotationProviderFactory.java:62) 在 org.apache.myfaces.config.annotation.AnnotationConfigurator.createFacesConfig(AnnotationConfigurator.java:90) 在 org.apache.myfaces.config.DefaultFacesConfigurationProvider.getAnnotationsFacesConfig(DefaultFacesConfigurationProvider.java:201) 在 org.apache.myfaces.config.DefaultFacesConfigurationMerger.getFacesConfigData(DefaultFacesConfigurationMerger.java:92) 在 org.apache.myfaces.config.FacesConfigurator.configure(FacesConfigurator.java:603) 在 org.apache.myfaces.webapp.AbstractFacesInitializer.buildConfiguration(AbstractFacesInitializer.java:456) 在 org.apache.myfaces.webapp.Jsp21FacesInitializer.initContainerIntegration(Jsp21FacesInitializer.java:70) 在 org.apache.myfaces.webapp.AbstractFacesInitializer.initFaces(AbstractFacesInitializer.java:190) 在 org.apache.myfaces.webapp.StartupServletContextListener.contextInitialized(StartupServletContextListener.java:103) 在 com.ibm.ws.webcontainer.webapp.WebApp.notifyServletContextCreated(WebApp.java:1736) 在 com.ibm.ws.webcontainer.webapp.WebAppImpl.initialize(WebAppImpl.java:415) 在 com.ibm.ws.webcontainer.webapp.WebGroupImpl.addWebApplication(WebGroupImpl.java:88) 在 com.ibm.ws.webcontainer.VirtualHostImpl.addWebApplication(VirtualHostImpl.java:171) 在 com.ibm.ws.webcontainer.WSWebContainer.addWebApp(WSWebContainer.java:904) 在 com.ibm.ws.webcontainer.WSWebContainer.addWebApplication(WSWebContainer.java:789) 在 com.ibm.ws.webcontainer.component.WebContainerImpl.install(WebContainerImpl.java:427) 在 com.ibm.ws.webcontainer.component.WebContainerImpl.start(WebContainerImpl.java:719) 在 com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:1211) 在 com.ibm.ws.runtime.component.DeployedApplicationImpl.fireDeployedObjectStart(DeployedApplicationImpl.java:1462) 在 com.ibm.ws.runtime.component.DeployedModuleImpl.start(DeployedModuleImpl.java:641) 在 com.ibm.ws.runtime.component.DeployedApplicationImpl.start(DeployedApplicationImpl.java:1040) 在 com.ibm.ws.runtime.component.ApplicationMgrImpl.start应用程序(ApplicationMgrImpl.java:795) 在 com.ibm.ws.runtime.component.ApplicationMgrImpl$5.run(ApplicationMgrImpl.java:2279) 在 com.ibm.ws.security.auth.ContextManagerImpl.runAs(ContextManagerImpl.java:5482) 在 com.ibm.ws.security.auth.ContextManagerImpl.runAs系统(ContextManagerImpl.java:5698) 在 com.ibm.ws.security.core.SecurityContext.runAsSystem(SecurityContext.java:255) 在 com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:2284) 在 com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:436) 在 com.ibm.ws.runtime.component.CompositionUnitImpl.start(CompositionUnitImpl.java:123) 在 com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:379) com.ibm.ws.runtime.component.CompositionUnitMgrImpl.access500 美元(CompositionUnitMgrImpl.java:127) 在 com.ibm.ws.runtime.component.CompositionUnitMgrImpl$CUInitializer.run(CompositionUnitMgrImpl.java:985) 在 com.ibm.wsspi.runtime.component.WsComponentImpl$_AsynchInitializer.run(WsComponentImpl.java:524) 在 com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1892)

WebSphere 8.5.5 默认提供 MyFaces JSF 2.0 实现。 IllegalArgumentException 表明 WAS 提供的 JSF 实现仍处于启用状态,并且您随应用提供的 MyFaces 2.3 实现与其冲突。

您需要按照 IBM 的说明[1] 使用“第三方 JSF 实现”:将服务器配置为对 JSF 使用 Sun RI 1.2 而不是“默认”或“MyFaces”,并提供您的 MyFaces 2.3作为独立共享库的实现及其依赖项。

[1] https://www.ibm.com/support/knowledgecenter/en/SSAW57_8.5.5/com.ibm.websphere.nd.multiplatform.doc/ae/tweb_jsf.html