zoukankan      html  css  js  c++  java
  • Struts2中Action对象的set方法和get方法调用规则

        Struts的Action是采用的是多实例多线程设计,而不是像Servlet那样采用单实例多线程设计,因此在struts中,一个请求就对应一个Action对象,个对象之间的数据相互之间互不干扰。没接到一个新的请求,就产生一个新的Action对象,并对Action对象的各属性赋予默认初始值。之后再根据一定的规则调用set方法给各属性赋值,并根据一定规则调用get方法。也就是说,Action对象不是一开始就必须调用set方法的。本文重点讲Action对象调用set和get方法的规则:

    1.get方法的调用规则

        Action对象get方法的调用规则相对简单,因此先说get方法的调用规则。调用get方法方法是为了获取属性值,这一点不仅仅在struts中是这样,在任何java程序中,都是这样的。那么什么时候才需要一个Action对象的属性值呢?就目前本人探索和总结的结果来看,分为以下三种情况:

    (一)、在Action请求转发到下一个Action时(即result的type属性为chain时),下一个Action有对应属性的set方法;

        这种情况是为了传递数据,让数据跟着Action流程的流转而进入到下一个Action对象,因此是非常重要的。但是呢,这种传递不一定能达到想要的目的,意外出现在如果最初的http请求本身就有了对应的查询参数值,则目标Action会在获得了源Action的get值之后,再次去过的请求的查询参数值,并用这个值作为set方法的传入参数,在这种情况下,目标Filed的值还是http请求的查询参数值。

    (二)、在struts.xml配置文件中引用了相应的Action属性;

        这种情况其实是显式调用了get方法,所以一定会被调用,也没什么好说的。

    (三)有对应的request.getAttribute(),且之前没有用过相应的request.setAttribute()。

       这里说的request.getAttribute()一般出现在视图中,比如jsp的requestScope.filedName,或者显示的request.getAttribute() java 代码。

      Action对象get方法调用的具体规则流程如下:

    需要强调的是,只有在真正需要数据的时候,才会调用get方法,而不是在离开Action的时候。所以,在下一个Action的拦截器之后,到达Action时,上一个Action的get方法才被调用(因为这时需要给目标Action赋值了,而赋值需要值的来源,所以就要调用上一个Action的get方法以获得赋值的来源)。

    还有需要强调的是,需要get方法时,总是调用最近Action对象的get方法,如果最近的Action没有get方法,则调用次近的,知道最开始的那个Action。

    2.set方法的调用规则

        Action对象set方法的调用规则相对于get方法来说比较复杂。同样,在任何java程序中,set方法都是为了给对象的属性赋值,因此,set方法的调用规则关乎到Action对象的数据是怎么获取的,因此显得尤为重要。

        因为set方法是给Action对象数据赋值的,所以,要知道set方法的调用规则,首先要清楚Action对象的属性数据的来源有哪些。就本人目前探索和总结来看,Action对象的属性数据的来源有以下两类:(1)上一个Action的get方法、(2)http请求参数。这两类数据来源也就对应了set方法的调用规则。

    (一)从源Action的get方法中获得

        这种情况对应于get方法调用规则中的第一种情况,也是在Action转发时发生的,而且和get方法的第一种情况总是同时发生的,也就是说,这两张情况要么都发生,要么都不发生。两种情况共同完成Action对象的数据传递。

    (二)从请求参数中来

        如果有对应的请求参数值,则这种情况一定会发生,及时上一种情况已经发生过了。这样,如果源Action有对应的get方法,请求中也有对应的请求参数值(注意是getParameter到的值,而不是getAttribute到的值,Action是不能从request的Attribute中得到属性值的),则一个get方法会被调用两次,后面一次获取的是请求参数中的值,最终的属性值和请求参数一致。

        set方法调用规则的流程如下:

    测试用的代码如下:LoginAction是源Action,LoginAction2是目标Action。

     1 import com.opensymphony.xwork2.ActionSupport;
     2 import org.apache.logging.log4j.LogManager;
     3 import org.apache.logging.log4j.Logger;
     4 import org.apache.struts2.ServletActionContext;
     5 
     6 import javax.servlet.http.HttpServletRequest;
     7 import javax.servlet.http.HttpServletResponse;
     8 
     9 public class LoginAction2 extends ActionSupport{
    10     private final Logger log = LogManager.getLogger(getClass());
    11     private String username;
    12     private String password;
    13     private String usernameAndPassword;
    14     private int age;
    15 
    16     public String getUsername() {
    17         log.trace("getUsername is in invoked");
    18 
    19         return username;
    20     }
    21 
    22     public void setUsername(String username) {
    23         log.trace("setUsername is in invoked");
    24 
    25         this.username = username;
    26     }
    27 
    28     public String getPassword() {
    29         return password;
    30     }
    31 
    32     public void setPassword(String password) {
    33         this.password = password;
    34     }
    35 
    36     public String getUsernameAndPassword() {
    37         log.trace("getUsernameAndPassword is in invoked");
    38 
    39         return usernameAndPassword;
    40     }
    41 
    42     public void setUsernameAndPassword(String usernameAndPassword) {
    43         log.trace("setUsernameAndPassword is in invoked");
    44 
    45         this.usernameAndPassword = usernameAndPassword;
    46     }
    47 
    48     @Override
    49     public void validate() {
    50         log.trace("validate is invoked");
    51         HttpServletRequest request = ServletActionContext.getRequest();
    52         HttpServletResponse response = ServletActionContext.getResponse();
    53         System.out.println( request.getAttribute("age"));
    54     }
    55 
    56     public int getAge() {
    57         log.trace("getAge is invoked");
    58         System.out.println("getAge:  "+age);
    59 
    60         return 70;
    61     }
    62 
    63 //    public void setAge(int age) {
    64 //        log.trace("setAge is invoked");
    65 //        System.out.println("setAge:  "+age);
    66 //        this.age = age;
    67 //    }
    68 }
      1 package edu.whu.swe.learnstruts2;
      2 
      3 import com.opensymphony.xwork2.ActionContext;
      4 import com.opensymphony.xwork2.ActionSupport;
      5 import edu.whu.swe.learnstruts2.service.LoginService;
      6 import edu.whu.swe.learnstruts2.service.impl.LoginServiceImpl;
      7 import org.apache.logging.log4j.LogManager;
      8 import org.apache.logging.log4j.Logger;
      9 import org.apache.struts2.ServletActionContext;
     10 
     11 import javax.servlet.RequestDispatcher;
     12 import javax.servlet.ServletContext;
     13 import javax.servlet.http.HttpServletRequest;
     14 import javax.servlet.http.HttpServletResponse;
     15 
     16 
     17 public class LoginAction extends ActionSupport {
     18     private final Logger log = LogManager.getLogger(getClass());
     19     private String username;
     20     private String password;
     21     private String alianname;
     22     private String othertest;
     23     private int age;
     24 
     25     private final LoginService loginService = new LoginServiceImpl();
     26 
     27 
     28     public String execute() throws Exception {
     29 
     30 
     31         if (!loginService.isLogin(username, password)) {
     32 
     33             return INPUT;
     34 
     35         }
     36         HttpServletRequest request = ServletActionContext.getRequest();
     37         HttpServletResponse response = ServletActionContext.getResponse();
     38 //        request.setAttribute("age", 22);
     39 //        this.age=22;
     40 
     41 /** 因为是使用的框架,所以重定向语句之后的代码依旧会执行,但是业务逻辑已经转到定向后的地方了 */
     42 //        ServletContext context =request.getSession().getServletContext();
     43 //        RequestDispatcher dispatcher=context.getRequestDispatcher("/usernameInvalide.jsp");
     44 //        System.out.println("print this before dispatcher");
     45 //        dispatcher.forward(request,response);
     46 //        System.out.println("print this after dispatcher");
     47 //        age+=1000;
     48 
     49 
     50         //
     51         System.out.println("LoginAction is executed");
     52         return SUCCESS;
     53 
     54     }
     55 
     56     public String getUsernameAndPassword() {
     57         log.trace("getUsernameAndPassword is in invoked");
     58         return username + password;
     59     }
     60 
     61     public void setUsernameAndPassword(String usernameAndPassword) {
     62         log.trace("setUsernameAndPassword is in invoked");
     63 
     64     }
     65 
     66 
     67     public String getUsername() {
     68         log.trace("getUsername is in invoked");
     69         return username;
     70     }
     71 
     72     public void setUsername(String username) {
     73         log.trace("setUsername is in invoked");
     74         this.username = username;
     75     }
     76 
     77     public String getPassword() {
     78         return password;
     79     }
     80 
     81     public void setPassword(String password) {
     82         this.password = password;
     83     }
     84 
     85 
     86     public String getAlianame() {
     87         log.trace("getAlianame is in invoked");
     88 
     89         return alianname;
     90     }
     91 
     92     public void setAlianame(String alianname) {
     93         log.trace("setAlianame is in invoked");
     94 
     95         this.alianname = alianname;
     96     }
     97 
     98     public String getOthertest() {
     99         return othertest;
    100     }
    101 
    102     public void setOthertest(String othertest) {
    103         this.othertest = othertest;
    104     }
    105 
    106 
    107     @Override
    108     public void validate() {
    109         log.trace("validate is invoked");
    110     }
    111 
    112     public void setAge(int age) {
    113         log.trace("setAge is invoked");
    114         this.age = age + 33;
    115     }
    116 
    117     public int getAge() {
    118         log.trace("setAge is invoked");
    119         return 55;
    120     }
    121 }

    关键的struts.xml配置如下:

    <action name="login1" class="edu.whu.swe.learnstruts2.LoginAction2">
                <result name="success">/welcome.jsp</result>
    </action>
    
    
    <action name="login" class="edu.whu.swe.learnstruts2.LoginAction">
                <result name="success" type="chain">
                    <param name="actionName">login1</param>
                    <param name="namespace">/</param>
                </result>
    </action>

     测试结果如下:

    不输入age
    2018-01-12 16:34:58.876 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 16:34:58.877 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 16:34:58.877 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 16:34:58.878 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    2018-01-12 16:34:58.878 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 16:34:58.878 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:34:58.878 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 16:34:58.879 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 16:34:58.879 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:34:58.880 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 16:34:58.883 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 16:34:58.883 TRACE edu.whu.swe.learnstruts2.LoginAction2 getAge - " getAge is invoked " 
    2018-01-12 16:34:58.884 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    
    输入了age
    2018-01-12 16:35:36.356 TRACE edu.whu.swe.learnstruts2.LoginAction setAge - " setAge is invoked " 
    2018-01-12 16:35:36.356 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 16:35:36.357 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 16:35:36.358 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 16:35:36.358 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    2018-01-12 16:35:36.358 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 16:35:36.359 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:35:36.359 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 16:35:36.359 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 16:35:36.360 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    2018-01-12 16:35:36.360 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:35:36.360 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 16:35:36.363 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 16:35:36.363 TRACE edu.whu.swe.learnstruts2.LoginAction2 getAge - " getAge is invoked " 
    2018-01-12 16:35:36.363 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    
    
    没有age表单
    2018-01-12 16:37:41.549 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 16:37:41.591 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 16:37:41.610 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 16:37:41.611 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    2018-01-12 16:37:41.611 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 16:37:41.611 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:37:41.612 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 16:37:41.612 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 16:37:41.615 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:37:41.622 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 16:37:41.741 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 16:37:41.741 TRACE edu.whu.swe.learnstruts2.LoginAction2 getAge - " getAge is invoked " 
    2018-01-12 16:37:41.742 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    
    没有age表单,在源Action有getAge{return age+55}和setAge{this.age=age+33},返回页面结果是:age:55
    2018-01-12 16:47:33.884 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 16:47:33.933 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 16:47:33.955 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 16:47:33.955 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    2018-01-12 16:47:33.956 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 16:47:33.956 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:47:33.956 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 16:47:33.957 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 16:47:33.960 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:47:33.971 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 16:47:34.132 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 16:47:34.133 TRACE edu.whu.swe.learnstruts2.LoginAction2 getAge - " getAge is invoked " 
    2018-01-12 16:47:34.134 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    
    
    输入age表单值为666,在源Action有getAge{return age+55}和setAge{this.age=age+33},在目标Action中打印相应的Filed。返回页面结果是:age:22
    2018-01-12 17:19:51.730 TRACE edu.whu.swe.learnstruts2.LoginAction setAge - " setAge is invoked " 
    2018-01-12 17:19:51.731 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 17:19:51.731 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 17:19:51.734 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 17:19:51.734 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    setAge:  754
    2018-01-12 17:19:51.735 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 17:19:51.736 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 17:19:51.736 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 17:19:51.736 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 17:19:51.737 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    setAge:  666
    2018-01-12 17:19:51.737 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 17:19:51.738 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 17:19:51.741 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 17:19:51.741 TRACE edu.whu.swe.learnstruts2.LoginAction2 getAge - " getAge is invoked " 
    getAge:  666
    2018-01-12 17:19:51.742 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    
    
    
    输入age表单值为666,在源Action有getAge{return age+55}和setAge{this.age=age+33},设置setAttribute("age",22);在目标Action中打印相应的Filed。返回页面结果是:age:22
    2018-01-12 16:56:50.179 TRACE edu.whu.swe.learnstruts2.LoginAction setAge - " setAge is invoked " 
    2018-01-12 16:56:50.195 TRACE edu.whu.swe.learnstruts2.LoginAction setUsername - " setUsername is in invoked " 
    2018-01-12 16:56:50.229 TRACE edu.whu.swe.learnstruts2.LoginAction validate - " validate is invoked " 
    LoginAction is executed
    2018-01-12 16:56:50.249 TRACE edu.whu.swe.learnstruts2.LoginAction getAge - " setAge is invoked " 
    2018-01-12 16:56:50.250 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    setAge:  754
    2018-01-12 16:56:50.250 TRACE edu.whu.swe.learnstruts2.LoginAction getUsername - " getUsername is in invoked " 
    2018-01-12 16:56:50.250 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:56:50.251 TRACE edu.whu.swe.learnstruts2.LoginAction getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
    2018-01-12 16:56:50.251 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsernameAndPassword - " setUsernameAndPassword is in invoked " 
    2018-01-12 16:56:50.253 TRACE edu.whu.swe.learnstruts2.LoginAction2 setAge - " setAge is invoked " 
    setAge:  666
    2018-01-12 16:56:50.255 TRACE edu.whu.swe.learnstruts2.LoginAction2 setUsername - " setUsername is in invoked " 
    2018-01-12 16:56:50.263 TRACE edu.whu.swe.learnstruts2.LoginAction2 validate - " validate is invoked " 
    2018-01-12 16:56:50.414 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsername - " getUsername is in invoked " 
    2018-01-12 16:56:50.415 TRACE edu.whu.swe.learnstruts2.LoginAction2 getUsernameAndPassword - " getUsernameAndPassword is in invoked " 
  • 相关阅读:
    关于apicloud ios自定义模块引用第三方framework not found for architecture armv7
    C#实现生产消费者模式
    C# unity 的 IInterceptionBehavior实现aop拦截器
    递归算法,如何把list中父子类对象递归成树
    php后台权限管理
    php生成json或者xml数据
    PHP实现异步调用方法研究
    PHP判断请求是否是ajax请求
    PHP开发网站之微信登录、绑定
    Linux_10------Linux之shell编程------变量
  • 原文地址:https://www.cnblogs.com/JMLiu/p/8277435.html
Copyright © 2011-2022 走看看