jsf-2之Weblogic 10.3.5 : prefer-web-inf-classes> in weblogic. xml 不工作 VS。服务器类路径 JAR 文件

Renyi-Fan 阅读:37 2025-02-15 21:57:57 评论:0

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 文件,我发现:

  1. 启动日志中不断报错版本的依赖。
  2. 在运行时继续使用正确版本的依赖项。

请您参考如下方法:

有时 <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">


标签:WEB
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

关注我们

一个IT知识分享的公众号