struts1的处理流程 和配置文件详解


  1. 1、struts1的处理流程  
  2.     首先:由视图层发出请求,当 ActionServlet 接收到 HTTP 请求后,在 doGet 或 doPost 方法中都会调用process()方法处理请求  
  3.     其次:在ActionServlet 的 process() 方法中一旦选择了正确的子应用模块,就会调用RequestProcessor实例的process()方法来处理请求。在ActionServlet调用这个方法时,会把当前的request和response对象传给它  
  4.     然后:RequestProcessor实例的process()方法调用ProcessActionCreate()方法,先判断是否在 Action 缓存中存在Action实例,如果不存在,就创建一个Action实例,把它保存在 Action 缓存中  
  5.     最后:RequestProcessor实例的process()方法调用Action实例的execute()方法 并返回相应的试图界面  
  6.   
  7. 2、struts1配置文件中action的常用属性  
  8. 首先列举action的属性代码如下:  
  9.         "URL"   
  10.                 type="ActionClass"   
  11.                 name="userForm"   
  12.                 scope="request"   
  13.                 attribute="key"   
  14.                 input="/register.jsp"  
  15.                 forward="/index.jsp"   
  16.                 include="/index.jsp"   
  17.                 unknown="true"   
  18.                 parameter="test"   
  19.                 className="mappingclass"  
  20.                 validate="true">  
  21.                 "" path="">  
  22.             
  23. 下面就对其属性解析  
  24.        a、path :代表请求的Action的名称,无需指明后缀struts1自动处理  
  25.        例如上一节中的/Register 就是从视图中提交的Action请求 此请求有的方式是:  
  26.          "${pageContext.request.contextPath}/Register.do" method="post">....  
  27.        当其点击此提交时后缀名称为.do,(由于我们在会web.xml配置*.do的处理),所以经过mapping的地址映射,交给ActionServlet按照struts1的处理流程处理提交Action的请求。  
  28.   
  29.        b、type:代表请求的的Action交给那个Action处理,注意此类的名称一定是类的全名称(包括包名)  
  30.   
  31.    c、name:代表的是请求参数封装的ActionForm的名称。   
  32. 备注:此名称与"名称Form" type="Form类的全名">中"名称Form"一致,并通过此form-bean中的type来指定封装的ActionForm类。  
  33.   
  34.        d、scope:代表把formbean的参数封装到那个作用域中,默认的作用域为session  
  35.     备注:当我们没有指定formbean的作用域时,在type指定的Action类中还可以通过以下代码获取:  
  36.          /** 获取ActionForm中的对象 并强制造型为UserForm 此获取方式为通过传递的ActionForm参数直接获取,开发中就是用此方式 */  
  37.         // UserForm userForm = (UserForm) form;  
  38.         /** 
  39.          * 由于在Action的属性配置中的scope属性指定了userForm的作用域, 当采用的是默认值(session)时, 
  40.          * 也可以直接从作用域中获取代码如下: 
  41.          */  
  42.         UserForm userForm = (UserForm) request.getSession().getAttribute("userForm");  
  43.           
  44.         System.out  
  45.                 .println("用户名称:" + userForm.getUsername() + " 用户密码:"  
  46.                         + userForm.getUserpass() + "   用户邮箱:"  
  47.                         + userForm.getUseremail());  
  48.       /**备注: 
  49. 由于在开发的过程中为了节省ActionForm占用的内存空间,我们一般不采用默认值,而是采用scope=”request”配置,因此我们也可以采用一下的方式获取*/  
  50. UserForm userForm = (UserForm) request.getAttribute("userForm");  
  51.   
  52.    注意:由于在aciton的配置中我们没有配置attribute="key" 此属性时,在Action中获取的关键字采用默认的值及name的名称,当配置了attribute="key"此属性是必须通过"key"获取.如果你不明白看下面的介绍。  
  53.   
  54.       E、attribute 指定formbean存储的key,不设默认为name属性的值。  
  55.    举例:如果我们在action的配置中配置了attribute=”uform”的话,那么我们在Action中获取的方式就应该为:  
  56.  /** 通过方法参数中传递的ActionForm获取ActionForm中的对象  
  57. 并强制造型为UserForm */  
  58. UserForm userForm = (UserForm) form;  
  59. /**由于在action的配置中我们指明了attribute的属性及属性值,因此我们应该采用以下方式获取*/  
  60.         UserForm userForm = (UserForm) request.getAttribute("uform");  
  61.         System.out  
  62.                 .println("用户名称:" + userForm.getUsername() + " 用户密码:"  
  63.                         + userForm.getUserpass() + "   用户邮箱:"  
  64.                         + userForm.getUseremail());  
  65.   备注:在指明了attribute属性后,我们如果还采用d中介绍方式即直接从作用域通过name的属性值获取的话,会出现javax.servlet.ServletException: java.lang.NullPointerException异常信息.  
  66.   
  67.    F、input="/register.jsp" 指定formbean的数据是由哪个页面提供的。  
  68. 说明:提供此属性的目的在于formbean校验失败时,程序方便 跳回formbean的输入页面,通过struts1错误信息标签,显示校验失败信息。  
  69.    G、forward="/index.jsp" 指定收到请求时,跳转到相应的jsp页面  
  70. 强调:如果配置了此属性,则action将不再被调用,即接受到此action时,直接调至到index.jsp页面。  
  71.    H、include="/index.jsp" 指定收到请求时,进行页面包含  
  72.    I、unknown="true" 如果action把该属性设置为true,则它可以处理客户机发出的所有无效的.do请求,默认值为false  
  73. 举例:如果在配置文件中添加如下的action配置,  
  74. "/**" forward="/index.jsp"  unknown="true"/>  
  75.    当如果在地址栏中发出请求为:  
  76. http://localhost:8080/20110105struts1_2/regi.do  
  77.    如果在此配置文件中找不到regi.do的Action就会处理上面配置的action直接跳转到index.jsp页面 (备注:与此action中path名称无关,但必须配置一个path属性).  
  78.    J、parameter="test"配置action参数,调用actioMapping.getParameter方法可以获得这里配置的参数(后续会详细介绍)  
  79.    K、className="mappingclass" 标签和所有的配置信息使用哪个对象封装,默认值为ActionMapping对象。这是struts1的作者考虑,开发者使用自己开发的Mapping类提供的配置.  
  80.    L、validate="true" 请求参数封装到formbean中后,是否让struts自动调用formbean的validate方法进行数据校验。默认true(后续会详细介绍)  
  81. 除此之外还用一些属性配置,我只做了常用属性的介绍.  
  82. 3、forward标签  
  83. 在action配置中,还有一些其他的标签配置,在上面种我们看到了"" path=""> 即在处理完此action之后我们可以在Action中的execute方法中通过此标签的name属性获取此action,并跳转到相应的path地址中去.  
  84. 举例:如果在action内部我们配置了forward标签的代码如下:  
  85. "message" path="/message.jsp">  
  86.   那么我们可以再Action返回值中做如下处理:  
  87. /** 获取跳转的地址并返回ActionForward */  
  88.         return mapping.findForward("message");  
  89. 通过以上配置,在处理完此action后,struts1经过处理后就会跳转到/message.jsp视图层.  
  90.   

你可能感兴趣的:(struts1)