Web项目在tomcat运行正常,移至weblogic后页面报错的问题

时间:2022-02-14 16:00:02

万分感谢     厦门老胡http://blog.csdn.net/hdfyq/article/details/5752912   的分享,解决了困扰我半个月的难题。


特将问题记录,以备日后需要:


问题描述:IPP5.1.1(我们产品的名字)部署在weblogic10.3.6上,运行正常,但是登录后台后页面报错,报错信息如下:

javax.servlet.ServletException: weblogic.servlet.jsp.CompilationException: Failed to compile JSP /WEB-INF/jsp/frame/perspective_content.jsp
perspective_content.jsp:1:1: The validator class: "org.apache.taglibs.standard.tlv.JstlCoreTLV" has failed with the following exception: "java.lang.ClassCastException: weblogic.xml.jaxp.RegistrySAXParserFactory cannot be cast to javax.xml.parsers.SAXParserFactory".
<%@ page contentType="text/html; charset=utf-8"%>


问题分析:经过一步步的定位排查,确定问题是jstl标签解析错误导致(页面包含:<%@ taglib prefix="c" uri="/tags/c.tld"%>, 去掉后页面就能正常打开)。

   多次测试后发现,当weblogic.xml中的<prefer-web-inf-classes>true</prefer-web-inf-classes> 参数改为“false”时,jstl中的c标签能解析正常,但是工程又

  无法正常启动,于是进入一个矛盾地:

<prefer-web-inf-classes>参数为true,工程启动正常,但是配置了<%@ taglib prefix="c" uri="/tags/c.tld"%>的页面无法打开;

<prefer-web-inf-classes>参数为true,配置了<%@ taglib prefix="c" uri="/tags/c.tld"%>的页面能打开,但是工程无法启动(通过测试小程序发现,

因为工程无法启动,该工程下的页面是无法访问的)

  这个问题就像一个无解的结困扰着我。


问题解决:多亏了厦门老胡http://blog.csdn.net/hdfyq/article/details/5752912 的博客

   问题解决总共分了三部:

1.将工程/WEB-INF/lib/下的 antlr-2.7.6.jar  复制到weblogic下  /home/Oracle/Middleware/wlserver_10.3/server/lib  路径下;

2.修改weblogic的启动配置文件startWeblogic.sh(/home/Oracle/Middleware/user_projects/domains/base_domain/bin)

在CLASSPATH="${SAVE_CLASSPATH}" 下面加入以下内容:

PRE_CLASSPATH="${WL_HOME}/server/lib/antlr-2.7.6.jar:"
CLASSPATH="${PRE_CLASSPATH}${SAVE_CLASSPATH}"

如下图:

Web项目在tomcat运行正常,移至weblogic后页面报错的问题


3.将WEB-INF/weblogic.xml中的<prefer-web-inf-classes>true</prefer-web-inf-classes>参数修改为false(若无此文件,则不需要此步骤);