严重: Error filterStart,StrutsPrepareAndExecuteFilter,解决:struts2系统加载时出现的异常

本文详细介绍了在使用Struts2 2.1.8版本时,遇到Tomcat 5.0版本不兼容导致的系统启动失败问题。通过深入分析日志文件和排查web.xml配置,最终确定问题源于StrutsPrepareAndExecuteFilter与Tomcat版本冲突。文章提供了移除冲突jar文件并重启服务的解决方案,确保系统恢复正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

郁闷了一天,终于在下班的时候把问题给解决了.
系统在启动加载web.xml时控制台提示:
严重: Error filterStart
严重: Context startup failed due to previous errors
系统无法启动,404错误.
通过检查web.xml文件发现问题出在struts2的filter上,

<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>


StrutsPrepareAndExecuteFilter是struts2 2.1.*之后的才有的,2.0.*没有该filter,之前为FilterDispatcher.
该系统使用struts2-core-2.1.8版本,各个必须包都齐全;JDK1.5,tomcat5.0
这些都不存在问题.
现在提供排错的一种方式:
控制台输出信息太少不足以定位错误,需要进入tomcat查看它的日志文件.
发现具体出错信息为:Exception starting filter struts2
javax.xml.transform.TransformerFactoryConfigurationError: Provider org.apache.xalan.processor.TransformerFactoryImpl not found
at javax.xml.transform.TransformerFactory.newInstance(Unknown Source)
at com.opensymphony.xwork2.util.DomHelper$DOMBuilder.<clinit>(DomHelper.java:159)
at com.opensymphony.xwork2.util.DomHelper.parse(DomHelper.java:107)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadConfigurationFiles(XmlConfigurationProvider.java:893)
导致该悲剧的原因就是tomcat的版本问题,5.0的版本太老.它的common\endorsed下的
xercesImpl.jar,xmlParserAPIs.jar与struts2有冲突,将其删掉重起服务,一切和谐了.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值