老项目Struts2.3升级到2.5过程中遇到的问题

1、Struts2找不到org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter

https://blog.csdn.net/hgx_suiyuesusu/article/details/78167616

2、ClassNotFoundException: org.apache.logging.log4j.Logger
https://blog.csdn.net/weixin_42756361/article/details/102502842
https://bbs.csdn.net/topics/392182439
在这里插入图片描述

<dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.11.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.11.0</version>
        </dependency>

3、org.apache.struts2.convention.DefaultClassFinder - Unable to read class
https://blog.csdn.net/qq_16711967/article/details/79345906

4、java.lang.NoSuchMethodError:org.apache.commons.lang3.reflect.MethodUtils.getAnnotation
https://blog.csdn.net/qq_44790703/article/details/108078498

5、Struts jsp标签问题,有两个错误。
5.1、org.apache.jasper.JasperException: /main/synccontent/retransquery/manage_list.jsp(24,5) Attribute id invalid for tag bean according to TLD
这个问题,是jar包升级后,原有的标签写法不能用了,这也是Struts的一个缺点,版本升级居然不做向下兼容,导致我这边的jsp用的低版本标签,全部作废,第一想法就是,修改jsp页面了,这工作量太大了,不现实。于是,想到了自定义标签的办法,来解决这个兼容问题

首先在web.xml里配置关联自定义标签的文件

	<jsp-config>
		<taglib>
			<taglib-uri>/struts-tags</taglib-uri>
			<taglib-location>/WEB-INF/struts-tags.tld</taglib-location>
		</taglib>
	</jsp-config>

然后,编写struts-tags.tld文件,内容如下,可以复制直接使用,添加tag和attribute标签

<?xml version="1.0" encoding="UTF-8"?>
<taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.0" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd">
	<description><![CDATA["To make it easier to access dynamic data;
		the Apache Struts framework includes a library of custom tags.
		The tags interact with the framework's validation and internationalization features;
		to ensure that input is correct and output is localized.
		The Struts Tags can be used with JSP FreeMarker or Velocity."
	]]></description>
	<display-name>"Struts Tags"</display-name>
	<tlib-version>2.2.3</tlib-version>
	<short-name>s</short-name>
	<uri>/struts-tags</uri>
<tag>
		<description><![CDATA[Print out expression which evaluates against the stack]]></description>
		<name>property</name>
		<tag-class>org.apache.struts2.views.jsp.PropertyTag</tag-class>
		<body-content>empty</body-content>
		<attribute>
			<description><![CDATA[The default value to be used if <u>value</u> attribute is null]]></description>
			<name>default</name>
			<required>false</required>
			<rtexprvalue>false</rtexprvalue>
		</attribute>
		<attribute>
			<description><![CDATA[ Whether to escape HTML]]></description>
			<name>escape</name>
			<required>false</required>
			<rtexprvalue>false</rtexprvalue>
		</attribute>
		<attribute>
			<description><![CDATA[Whether to escape Javascript]]></description>
			<name>escapeJavaScript</name>
			<required>false</required>
			<rtexprvalue>false</rtexprvalue>
		</attribute>
		<attribute>
			<description><![CDATA[Value to be displayed]]></description>
			<name>value</name>
			<required>false</required>
			<rtexprvalue>false</rtexprvalue>
		</attribute>
		<dynamic-attributes>false</dynamic-attributes>
	</tag>
</taglib>

这样配置好后,就可以解决上述问题

5.2、javax.servlet.ServletException: /main/synccontent/retransquery/manage_list.jsp(129,21) Unable to find setter method for attribute: escape
这个问题是基于5.1解决之后,产生的问题,attribute 配置问题。我这边升级的jar版本是
struts2-core-2.5.26.jar。但是,自定义标签配置中,escape attribute 对应的java类,没有set方法,导致的这个错误。
我们查看struts-tags.tld配置文件,发现,对应的class是

<tag-class>org.apache.struts2.views.jsp.PropertyTag</tag-class>

可以看出,它是Struts jar包中的类。
全局搜索出这个PropertyTag.class文件,会发现,里面确实没有escape对应的set方法
于是,修补jar包,加上set方法即可

6、tag ‘select’, field ‘list’, name ‘contentType’: The requested list key ‘#syscodeBean.syscodeBysernoList’ could not be resolved as a collection/array/map/enumeration/iterator type. Example: people or people.{name} - [unknown location]
访问jsp页面总是报这个错误

排查过程:
首先看错误日志,找到这个错误片段,但是,还是很难定位原因
然后,启动本地项目,访问同一个jsp页面,居然是好的,看来是项目代码管理乱了
再叫运维拉服务器代码,到本地查看比对两个页面的差异
发现,不一样的地方是

服务器代码:
<s:bean name="com.linkage.system.components.system.ui.pagebean.SyscodeBean" id="syscodeBean">
本地代码:
<s:bean name="com.linkage.system.components.system.ui.pagebean.SyscodeBean" var="syscodeBean">

会发现,是id和var变量的问题
这里就涉及到Struts2的自定义标签的知识点
按住ctrl,点击id,进入tld配置文件,找到class
org.apache.struts2.views.jsp.BeanTag
直觉判断,是Struts2的标签里把变量名定义成var,所以,用id时候无法识别
于是,debug,发现

org.apache.struts2.views.jsp.BeanTag中

    protected void populateParams() {
        super.populateParams();
        ((Bean)this.component).setName(this.name);
    }

发现,用id的时候,component里面对应的变量var是null
查看ContextBeanTag.super.populateParams();
发现,这里定义了变量名是var,于是,确定了根源在这个class文件的不兼容问题上
在找到低版本的jar,查看同名文件,发现低版本的里面

    public void setId(String id) {
        this.setVar(id);
    }

通过这个方法,吧id值传给了var变量,从而做到了兼容效果,解决了该问题

补充:问题的排除思路,拉取 Tomcat 的 localhost log 和 catalina log

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值