当您遇到“怪异”的异常提示时,虽然类/方法/文件/组件/标签似乎已明确包含在Web应用程序中(例如以下类),但它们却不存在或不同,
java.lang.ClassFormatError:类文件javax / faces / webapp / FacesServlet中不是本机或抽象的方法中的缺少Code属性
java.util.MissingResourceException:找不到javax.faces.LogStrings包
com.sun.faces.vendor.WebContainerInjectionProvider无法转换为com.sun.faces.spi.InjectionProvider
com.sun.faces.config.ConfigurationException:配置失败
来自命名空间http://xmlns.jcp.org/jsf/html的名为inputFile的标签定义了一个空处理程序类。
javax.faces.CurrentThreadToServletContext.getFallbackFactory上的java.lang.NullPointerException
javax.faces.application.ViewHandlerWrapper.getWebsocketURL处的java.lang.AbstractMethodError
或当您遇到“古怪”的运行时行为,例如HTTP会话损坏(jsessionid
出现在所有位置的链接URL中)和/或JSF视图范围损坏(行为与请求范围相同),和/或CSS / JS / image损坏资源,那么很有可能Web应用程序的运行时类路径被重复的不同版本的JAR文件污染。
在您的具体情况与ClassFormatError
上FacesServlet
,这意味着包含上述类的JAR文件已被发现,第一次实际上是一个“蓝图”API JAR文件,intented实施供应商(如钻嘴鱼科和MyFaces的的开发人员) 。它包含仅具有类和方法签名的类文件,而没有任何代码体和资源文件。这正是“缺少代码属性”的含义。纯粹是为了javadocs和编译。
在Maven中标记为“ Java规范 ”并-api
在工件ID中带有后缀的所有依赖项都是那些蓝图API。您绝对不应在运行时类路径中包含它们。<scope>provided</scope>
如果确实需要将其添加到pom中,则应始终对其进行标记。一个著名的例子是JavaEE(Web)API:
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-web-api</artifactId>
<version><!-- 7.0 or 8.0 or newer --></version>
<scope>provided</scope>
</dependency>
如果provided
范围不存在,则此JAR将最终出现在webapp的中/WEB-INF/lib
,从而导致您现在面临的所有麻烦。此JAR还包含的蓝图类FacesServlet
。
在您的特定情况下,您有不必要的JSFAPI依赖项:
<dependency>
<groupId>javax.faces</groupId>
<artifactId>javax.faces-api</artifactId>
</dependency>
这引起了麻烦,因为其中包含的蓝图类FacesServlet
。provided
如上所示,将其删除并依靠Java EE(Web)API即可解决。
Tomcat作为准系统JSP / Servlet容器,已经提供了JSP,Servlet和EL(以及8以及WebSocket)。所以,你应该标记至少jsp-api
,servlet-api
和el-api
作为provided
。Tomcat仅不提供开箱即用的JSF和JSTL。因此,您需要通过webapp安装它。
诸如WildFly,TomEE,GlassFish,Payara,WebSphere等成熟的Java EE服务器已经提供了完整的Java EE API,包括JSF。因此,您完全不需要通过webapp安装JSF。如果服务器已经提供了不同的实现方式和/或版本,则只会导致冲突。您唯一需要的依赖关系就是javaee- web-api
上面的显示。
在我们的JSFWiki-安装JSF中提到了在Tomcat中安装JSF的正确方法。有2个JSF实现,Mojarra和MyFaces。您应该选择安装其中之一,而 两者都安装。
在Tomcat上安装Mojarra:
<dependency>
<groupId>org.glassfish</groupId>
<artifactId>jakarta.faces</artifactId>
<version><!-- Check https://eclipse-ee4j.github.io/mojarra --></version>
</dependency>
您还可以检查org.glassfish:jakarta.faces
存储库中当前的最新发行版本(当前为2.3.14
)。另请参阅Mojarra安装说明
在Tomcat上安装MyFaces:
<dependency>
<groupId>org.apache.myfaces.core</groupId>
<artifactId>myfaces-bundle</artifactId>
<version><!-- Check http://myfaces.apache.org --></version>
</dependency>
您还可以检查org.apache.myfaces.core:myfaces-bundle
存储库中当前的最新发行版本(当前为2.3.5
)。
请注意,作为Servlet 2.5容器的Tomcat 6支持最大的JSF 2.1。
顺便说一句,不要忘记一起安装JSTL API。Tomcat中也不存在这种情况。
<dependency>
<groupId>jakarta.servlet.jsp.jstl</groupId>
<artifactId>jakarta.servlet.jsp.jstl-api</artifactId>
<version><!-- Check https://mvnrepository.com/artifact/jakarta.servlet.jsp.jstl/jakarta.servlet.jsp.jstl-api --></version>
</dependency>
还应注意,自JSF 2.3起,CDI已成为必需的依赖项。这在常规JavaEE服务器中是开箱即用的,但在诸如Tomcat之类的servlet容器中不可用。