使用 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作为独立共享库的实现及其依赖项。
我正在尝试使用 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作为独立共享库的实现及其依赖项。