jsf-2之Weblogic 10.3.5 : prefer-web-inf-classes> in weblogic. xml 不工作 VS。服务器类路径 JAR 文件
Weblogic版本:10.3.5
JSF 版本(接口(interface)、实现): Mojarra 2.0.3
我有一个 JSF EAR
应用程序,它由一个 WAR
文件和一个 JAR
文件组成。
WAR
文件包含以下两个Maven
依赖项:
<dependency>
<groupId>javax.faces</groupId>
<artifactId>jsf-api</artifactId>
<version>2.0.3</version>
</dependency>
<dependency>
<groupId>com.sun.faces</groupId>
<artifactId>jsf-impl</artifactId>
<version>2.0.3</version>
</dependency>
运行时,以下代码片段正确将 Mojarra
的当前服务版本报告为 v2.0.3:
public void getMojarraVersion() {
Package p = FacesContext.class.getPackage();
System.out.println("Mojarra version: " + p.getImplementationTitle() + " " + p.getImplementationVersion());
}
然而,weblogic 启动日志报告说,当应用程序启动时,使用了容器提供的一个不同的、更旧的版本:
INFO: Initializing Sun's JavaServer Faces implementation (1.2_03-b04-FCS) for context '/myApp'
这是尽管有以下 weblogic.xml
配置,与 WAR
文件的 web.xml
文件一起部署在 WEB-INF 中
,反转类加载器:
<?xml version="1.0" encoding="UTF-8"?>
<wls:weblogic-web-app xmlns:wls="http://xmlns.oracle.com/weblogic/weblogic-web-app" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/ejb-jar_3_0.xsd http://xmlns.oracle.com/weblogic/weblogic-web-app http://xmlns.oracle.com/weblogic/weblogic-web-app/1.4/weblogic-web-app.xsd">
<wls:container-descriptor>
<wls:prefer-web-inf-classes>true</wls:prefer-web-inf-classes>
</wls:container-descriptor>
</wls:weblogic-web-app>
经过几天的挖掘,我发现服务器类路径中包含以下两个 JAR 文件:
${WEBLOGIC_HOME}/wlserver_10.3/server/lib/consoleapp/webapp/WEB-INF/lib/jsf-api.jar
${WEBLOGIC_HOME}/wlserver_10.3/server/lib/consoleapp/webapp/WEB-INF/lib/jsf-impl.jar
这些文件由 Weblogic
10.3.5 的原始安装提供。
临时删除这两个 JAR 文件并重新启动服务器导致日志开始报告新版本正在使用中:
INFO: Initializing Mojarra 2.0.3 for context '/myApp'
因此,上述证据表明,用于颠覆类加载器层次结构的 Weblogic 配置对于服务器类路径(即 ${WEBLOGIC_HOME}/wlserver_10.3/server/lib
) 加载应用程序时。
有趣的是,我可以删除 weblogic.xml
文件,我发现:
- 启动日志中不断报错版本的依赖。
- 在运行时继续使用正确版本的依赖项。
请您参考如下方法:
有时 <wls:prefer-web-inf-classes>true</wls:prefer-web-inf-classes>
无法指定库。您需要使用:<wls:prefer-application-packages>
和 <wls:prefer-application-resources>
.下面是一个示例(删除 wls: 对于旧的 weblogic 版本):
<wls:container-descriptor>
<wls:prefer-application-packages>
<wls:package-name>META-INF/services/javax.xml.bind.JAXBContext</wls:package-name>
<wls:package-name>com.google.common.*</wls:package-name>
<wls:package-name>org.slf4j.*</wls:package-name>
<wls:package-name>org.apache.logging.log4j.*</wls:package-name>
</wls:prefer-application-packages>
<wls:prefer-application-resources>
<wls:resource-name>META-INF/services/javax.xml.bind.JAXBContext</wls:resource-name>
<wls:resource-name>com.google.common.*</wls:resource-name>
<wls:resource-name>org.slf4j.*</wls:resource-name>
<wls:resource-name>org.apache.logging.log4j.*</wls:resource-name>
</wls:prefer-application-resources>
</wls:container-descriptor>
在 weblogic.xml 之上使用这个: <wls:weblogic-web-app xmlns:wls="http://xmlns.oracle.com/weblogic/weblogic-web-app" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd http://xmlns.oracle.com/weblogic/weblogic-web-app http://xmlns.oracle.com/weblogic/weblogic-web-app/1.2/weblogic-web-app.xsd">
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。