JSF 2.2 webapp 可以在本地机器上运行,但不能在服务器上运行

JSF 2.2 webapp works on Local Machine but not on the Server

我正在尝试使用 jsf 2.2 创建 Web 应用程序。我的应用程序正在使用 JERSEY Restful、jre 1.8、JSF 2.2、Primefaces。

它在我的本地机器上运行良好,但在 AWS(EC2- Tomcat by bitnami-free tier)上我收到错误(错误日志在底部。)

非常感谢您的提前帮助。

我正在使用以下库

这是我的 Web.xml 文件代码:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>MYAPP</display-name>
 <welcome-file-list>
    <welcome-file>welcome.jsf</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>*.jsf</url-pattern>
  </servlet-mapping>
  <servlet>
    <servlet-name>Jersey Rest Service</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>Jersey Rest Service</servlet-name>
    <url-pattern>/webresources/*</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>
</web-app>

错误日志 2018 年 4 月 26 日 03:33:43.130 SEVERE [localhost-startStop-23] org.apache.catalina.core.StandardContext.listenerStart 向 class [com.sun.faces.config.ConfigureListener] 的侦听器实例发送上下文初始化事件异常 java.lang.RuntimeException: java.lang.NoSuchMethodError: javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 com.sun.faces.config.ConfigureListener.contextInitialized(未知来源) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4745) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5207) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:986) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 在 java.lang.Thread.run(Thread.java:748) 原因:java.lang.NoSuchMethodError:javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 org.primefaces.util.Jsf23Helper.addSearchKeywordResolvers(Jsf23Helper.java:27) 在 org.primefaces.webapp.PostConstructApplicationEventListener.processEvent(PostConstructApplicationEventListener.java:48) 在 javax.faces.event.SystemEvent.processListener(来源不明) 在 com.sun.faces.application.ApplicationImpl.processListeners(来源不明) 在 com.sun.faces.application.ApplicationImpl.invokeListenersFor(来源不明) 在 com.sun.faces.application.ApplicationImpl.publishEvent(来源不明) 在 com.sun.faces.config.ConfigManager.publishPostConfigEvent(来源不明) ... 还有 14 个

2018 年 4 月 26 日 03:33:43.463 SEVERE [localhost-startStop-23] org.apache.catalina.core.StandardContext.listenerStart 向 class [com.sun.faces.config.ConfigureListener 的侦听器实例发送上下文初始化事件异常] java.lang.RuntimeException: java.lang.NoSuchMethodError: javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 com.sun.faces.config.ConfigureListener.contextInitialized(未知来源) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4743) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5207) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:986) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 在 java.lang.Thread.run(Thread.java:748) 原因:java.lang.NoSuchMethodError:javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 org.primefaces.util.Jsf23Helper.addSearchKeywordResolvers(Jsf23Helper.java:27) 在 org.primefaces.webapp.PostConstructApplicationEventListener.processEvent(PostConstructApplicationEventListener.java:48) 在 javax.faces.event.SystemEvent.processListener(来源不明) 在 com.sun.faces.application.ApplicationImpl.processListeners(来源不明) 在 com.sun.faces.application.ApplicationImpl.invokeListenersFor(来源不明) 在 com.sun.faces.application.ApplicationImpl.publishEvent(来源不明) 在 com.sun.faces.config.ConfigManager.publishPostConfigEvent(来源不明) ... 还有 14 个

2018 年 4 月 26 日 03:39:45.299 严重 [localhost-startStop-24] org.apache.catalina.core.StandardContext.listenerStart 向 class [com.sun.faces.config.ConfigureListener 的侦听器实例发送上下文初始化事件异常] java.lang.RuntimeException: java.lang.NoSuchMethodError: javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 com.sun.faces.config.ConfigureListener.contextInitialized(未知来源) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4745) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5207) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:986) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 在 java.lang.Thread.run(Thread.java:748) 原因:java.lang.NoSuchMethodError:javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 org.primefaces.util.Jsf23Helper.addSearchKeywordResolvers(Jsf23Helper.java:27) 在 org.primefaces.webapp.PostConstructApplicationEventListener.processEvent(PostConstructApplicationEventListener.java:48) 在 javax.faces.event.SystemEvent.processListener(来源不明) 在 com.sun.faces.application.ApplicationImpl.processListeners(来源不明) 在 com.sun.faces.application.ApplicationImpl.invokeListenersFor(来源不明) 在 com.sun.faces.application.ApplicationImpl.publishEvent(来源不明) 在 com.sun.faces.config.ConfigManager.publishPostConfigEvent(来源不明) ... 还有 14 个

2018 年 4 月 26 日 03:39:45.716 严重 [localhost-startStop-24] org.apache.catalina.core.StandardContext.listenerStart 向 class [com.sun.faces.config.ConfigureListener 的侦听器实例发送上下文初始化事件异常] java.lang.RuntimeException: java.lang.NoSuchMethodError: javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 com.sun.faces.config.ConfigureListener.contextInitialized(未知来源) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4743) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5207) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:986) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 在 java.lang.Thread.run(Thread.java:748) 原因:java.lang.NoSuchMethodError:javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 org.primefaces.util.Jsf23Helper.addSearchKeywordResolvers(Jsf23Helper.java:27) 在 org.primefaces.webapp.PostConstructApplicationEventListener.processEvent(PostConstructApplicationEventListener.java:48) 在 javax.faces.event.SystemEvent.processListener(来源不明) 在 com.sun.faces.application.ApplicationImpl.processListeners(来源不明) 在 com.sun.faces.application.ApplicationImpl.invokeListenersFor(来源不明) 在 com.sun.faces.application.ApplicationImpl.publishEvent(来源不明) 在 com.sun.faces.config.ConfigManager.publishPostConfigEvent(来源不明) ... 还有 14 个

2018 年 4 月 26 日 04:57:18.310 严重 [localhost-startStop-25] org.apache.catalina.core.StandardContext.listenerStart 向 class [com.sun.faces.config.ConfigureListener 的侦听器实例发送上下文初始化事件异常] java.lang.RuntimeException: java.lang.NoSuchMethodError: javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 com.sun.faces.config.ConfigureListener.contextInitialized(未知来源) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4743) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5207) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:986) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 在 java.lang.Thread.run(Thread.java:748) 原因:java.lang.NoSuchMethodError:javax.faces.application.Application.addSearchKeywordResolver(Ljavax/faces/component/search/SearchKeywordResolver;)V 在 org.primefaces.util.Jsf23Helper.addSearchKeywordResolvers(Jsf23Helper.java:27) 在 org.primefaces.webapp.PostConstructApplicationEventListener.processEvent(PostConstructApplicationEventListener.java:48) 在 javax.faces.event.SystemEvent.processListener(来源不明) 在 com.sun.faces.application.ApplicationImpl.processListeners(来源不明) 在 com.sun.faces.application.ApplicationImpl.invokeListenersFor(来源不明) 在 com.sun.faces.application.ApplicationImpl.publishEvent(来源不明) 在 com.sun.faces.config.ConfigManager.publishPostConfigEvent(来源不明) ... 还有 14 个

您的项目中似乎包含了不同版本的 JSF,这导致了问题。我可以在您的依赖项中看到 javax.faces-2.3.2 以及 jsf-api-2.2.9/jsf-impl-2.2.9。 addSearchKeywordResolver 中的方法 javax.faces.application.Application 被调用但无法找到(正如堆栈跟踪告诉您的那样)。这种方法只 JSF 2.3 的一部分。然而,似乎使用了 JSF 2.2 class。该方法由 PrimeFaces 调用,因为 PrimeFaces 认为您使用的是 JSF 2.3,因为 class javax.faces.component.UIImportConstants 可以在 class 路径中找到(在 javax.faces-2.3 .2 依赖)。我认为解决方案是只包含一个 JSF 版本的依赖项。