当您遇到“怪异”的异常提示时,虽然类/方法/文件/组件/标签似乎已明确包含在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和编译。
始终将服务器提供的库标记为 provided
在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上面的显示。
在Tomcat上安装JSF
在我们的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容器中不可用。



