struts2中关于ognl.MethodFailedException错误的解决办法

本文分析了Struts2框架中出现Ognl.MethodFailedException的具体原因及解决方案,主要涉及参数类型不匹配导致的问题,并提出了四种常见错误场景及相应的解决办法。

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

 

在使用struts2的时候经常会出现:   ognl.MethodFailedException: Method "setDenddt" failed for objectcom.drw.pojo.KrigPrewarn@374a374a [java.lang.NoSuchMethodException: com.drw.pojo.KrigPrewarn.setDenddt([Ljava.lang.String;)]
 at ognl.OgnlRuntime.callAppropriateMethod(OgnlRuntime.java:1292)

这种错误。这种错误有时候对程序没影响,有时候会使程序报错。从错误的原因可以看出没有找到setDenddt([Ljava.lang.String;)]这个方法,检查实体类中setDenddt这个方法发现参数为Date类型的,而传过来的是string类型的,所以就找不到相应的方法。在struts2中利用值栈传值,传递参数的类型要与实体类保持一致。出现这种错误的原因主要有以下几种情况:

1.在js中利用利用这种方式进入action:  xxAction!queryforlist.action?denddt=参数值,这种方式传过去去的值默认为string类型的。

2.form元素的ectype没有设置成:enctype="multipart/form-data"。

3.form提交方式为method="get"。

4.传递值的时候没有进行相应的类型转换。

解决方法:

1.在实体类中字段全部声明为String类型的,然后在sql语句中在进行相应的转换。比如日期,实体类中为string类型的,在sql中转换为to_date(denddt,'yyyy-mm-dd').

2,在js传递值的时候进行相应的类型转换。

3.在log文件中加入如下配置:log4j.properties:
# Struts OgnlUtil issues unimportantwarnings
log4j.logger.com.opensymphony.xwork2.util.OgnlUtil=error
log4j.logger.com.opensymphony.xwork2.ognl.OgnlValueStack=error

15:30:30.601 [http-nio-8080-exec-5] ERROR org.apache.struts2.dispatcher.DefaultDispatcherErrorHandler - Exception occurred during processing request: ognl.OgnlAction.execute() java.lang.NoSuchMethodException: ognl.OgnlAction.execute() at ognl.OgnlRuntime.callAppropriateMethod(OgnlRuntime.java:1247) ~[ognl-3.0.19.jar:?] at ognl.ObjectMethodAccessor.callMethod(ObjectMethodAccessor.java:68) ~[ognl-3.0.19.jar:?] at com.opensymphony.xwork2.ognl.accessor.XWorkMethodAccessor.callMethodWithDebugInfo(XWorkMethodAccessor.java:117) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.ognl.accessor.XWorkMethodAccessor.callMethod(XWorkMethodAccessor.java:108) ~[xwork-core-2.3.32.jar:2.3.32] at ognl.OgnlRuntime.callMethod(OgnlRuntime.java:1370) ~[ognl-3.0.19.jar:?] at ognl.ASTMethod.getValueBody(ASTMethod.java:91) ~[ognl-3.0.19.jar:?] at ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212) ~[ognl-3.0.19.jar:?] at ognl.SimpleNode.getValue(SimpleNode.java:258) ~[ognl-3.0.19.jar:?] at ognl.Ognl.getValue(Ognl.java:467) ~[ognl-3.0.19.jar:?] at ognl.Ognl.getValue(Ognl.java:431) ~[ognl-3.0.19.jar:?] at com.opensymphony.xwork2.ognl.OgnlUtil$3.execute(OgnlUtil.java:352) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.ognl.OgnlUtil.compileAndExecuteMethod(OgnlUtil.java:404) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.ognl.OgnlUtil.callMethod(OgnlUtil.java:350) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:430) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:290) ~[xwork-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:251) ~[xwork-core-2.3.32.jar:2.3.32] at org.apache.struts2.interceptor.DeprecationInterceptor.intercept(DeprecationInterceptor.java:41) ~[struts2-core-2.3.32.jar:2.3.32] at com.opensymphony.xwork2.Defaul
最新发布
03-22
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值