struts2,action方法自动执行两次

发现一个比较有意思的bug,

//Action中以get开头且返回类型不为void(如 public Object  get*() )的方法会被自动执行
//放入值栈时会执行一次,
//若在页面调用则再执行一次

如下面这个method

public String getUserByID() {
        System.out.println("userAction.getUserByID()执行中。。。");
        
        idUser = userService.getUserByID(user.getUid());
        
        return SUCCESS;
}

若调用调用这个方法会发现,查询语句被执行了两次

UserAction.getUser()执行中。。。
userAction.getUserByID()执行中。。。
Hibernate: 
    select
        user0_.uid as uid1_0_0_,
        user0_.username as username2_0_0_,
        user0_.address as address3_0_0_ 
    from
        tbl_user user0_ 
    where
        user0_.uid=?
userAction.getIdUser()执行中。。。
userAction.getIdUser()执行中。。。
userAction.getIdUser()执行中。。。
userAction.getIdUser()执行中。。。
userAction.getUserList()执行中。。。
userAction.getPageList()执行中。。。
userAction.getIdUser()执行中。。。
userAction.getName()执行中。。。
UserAction.getPage()执行中。。。
userAction.getPageList()执行中。。。
UserAction.getUser()执行中。。。
userAction.getUserByID()执行中。。。
Hibernate: 
    select
        user0_.uid as uid1_0_0_,
        user0_.username as username2_0_0_,
        user0_.address as address3_0_0_ 
    from
        tbl_user user0_ 
    where
        user0_.uid=?
userAction.getUserList()执行中。。。

而且在执行其他method方法时也会调用这个方法,这样会导致程序跳出异常,把method名改为selectUserByID()问题解决

原文地址:https://www.cnblogs.com/annofyf/p/9797827.html