每次启动tomcat 时候上面写的action找不到方法但是下面又执行出来了出来结果 页面上也正常

java web项目 Struts+ibatis+jsp 的
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注
这些信息是拦截器执行的方法,在执行action的动作之前,先执行对应的validate()方法。引用某博客的解释:http://blog.csdn.net/jdluojing/article/details/7578027
大致了解一下validate方法执行的原理:首先我们需要知道,validate()这个方法是被拦截器调用的,拦截器放在动作执行之前,拦截每个访问该Action的请求。这个拦截器叫做Workflow拦截器,查看文档可以知道,该拦截器的实现类为com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor。文档中说这个拦截器要做的事情:
(1)如果Action中有validate{MethodName}()方法,那么执行它
(2)如果(1)不成立,但是Action中有validateDo{MethodName}()方法,那么执行它
(3)不管(1)或(2)是否执行,只要这个拦截器的alwaysInvokeValidate属性为true,那么总是会执行validate方法。
你的程序中没有定义这些校验方法,但是默认拦截器又会出发校验操作,所以会出现上述打印信息。最终你的Action方法还是被执行了的,因为默认的validate()方法应该是可以通过的。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报