Struts2 的 Action 被 无故 执行2次 或 执行多次

来源:百度文库 编辑:神马文学网 时间:2024/06/13 02:11:22

又郁闷了...

哎,...我都不想开Log4j了...

一开,一看,N多错误...

标题那个错误...有点搞笑...

 

具体是,你发出一个请求 ..../.../ssss.action

然后,你得到了一个结果...

好,你觉得你成功了!

但是一看后台(或者日志)

...

发现,你请求了一次,日志却出现了2次,而且是2次相同的...

吓死你...

然后你不信,以为日志错了,断点一看...

果然,一个Action被执行了2次!(甚至有多次的情况)

...

后来...

 

哎,原因在这里!

出现这种情况的人  都是用  SSS!SSSS.action 来执行的

也就是说一个 Action类中,有N个方法被当成Action来用

...

具体就是 你的方法名 用了  getXXX 为方法名

也就是说,如果你的Action是一个方法,而且以叹号的方式请求,方法还以get开头

如:getUserById() 、getACL() 等...

那么...你就会出现上面的错误...

 

解决方法很简单,帮你的方法换个名字

如:loadUserById()...

 

哎...继续