qq_25921615
暖暖的码农
采纳率100%
2015-05-05 05:40 浏览 1.4k
已采纳

java web项目 Struts+ibatis+jsp 的

![图片说明](https://img-ask.csdn.net/upload/201505/05/1430804330_885671.jpg)图片说明
每次启动tomcat 时候上面写的action找不到方法但是下面又执行出来了出来结果 页面上也正常

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答 默认 最新

  • 已采纳
    wojiushiwo945you 毕小宝 2015-05-05 06:01

    这些信息是拦截器执行的方法,在执行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()方法应该是可以通过的。

    点赞 评论 复制链接分享
  • qq_25921615 暖暖的码农 2015-05-05 05:42

    图片说明

    这是查出来的

    点赞 评论 复制链接分享

相关推荐