zoukankan      html  css  js  c++  java
  • Struts2 配置Action详解

     Struts2的核心功能是action,对于开发人员来说,使用Struts2主要就是编写action,action类通常都要实现com.opensymphony.xwork2.Action接口,并实现该接口中的execute()方法。

    该方法如下:

      

     public String execute() throws Exception

    Struts2并不是要求所有编写的action类都要实现Action接口,也可以直接编写一个普通的Java类作为action,只要实现一个返回类型为String的无参的public方法即可:

      

      public String  xxx()

    在实际开发中,action类很少直接实现Action接口,通常都是从com.opensymphony.xwork2.ActionSupport类继承,ActionSupport实现了Action接口和其他一些可选的接口,提供了输入验证,错误信息存取,以及国际化的支持,选择从ActionSupport继承,可以简化action的定义。

    开发好action之后,好需要对action进行配置,以告诉Struts2框架,针对某个URL的请求应该交由哪个action进行处理。

     

    1.    Action映射:
      action映射是Struts2框架中的基本” 工作单元”,action映射就是将一个请求URL(即action的名字)映射到一个action类,当一个请求匹配某个action的名字时,框架就使用这个映射来确定如何处理请求。
                       action元素的完整属性表

      属性

    是否必须

    说明

      name

    action的名字,用于匹配URL

      class

    Action实现类的完整类名

      method

    执行Action类时调用的方法

      convert

    应用于action的类型转换的完整类名



     

     

     

     

           例如:

    1 <action name="user" class="org.lesson05.UserAction">
    2 
    3                 <result name="success">/user.jsp</result>
    4 
    5         </action>

     

        2. 使用method属性
               在配置action时,我们可以通过action元素的method属性来指定action调用的
            方法,所指定的方法,必须遵循与execute方法相同的格式。
               在Struts2.xml文件中,我们可以为同一个action类配置不同的别名,并使用
            method属性。
               在Struts.xml文件中为同一个Action类配置不同的别名
             

     1    <!-- 使用method属性 -->
     2 
     3 <package name="methods" namespace="/"
     4 
     5 extends="struts-default">
     6 
     7         <!-- 对应着MethodAction里面的execute方法 -->
     8 
     9         <action name="list" class="org.lesson05.MethodAction">
    10 
    11             <result name="success">/Methods/list.jsp</result>
    12 
    13         </action>
    14 
    15         <!-- 对应着MethodAction里面的add方法 -->
    16 
    17         <action name="add" class="org.lesson05.MethodAction"
    18 
    19 method="add">
    20 
    21             <result name="success">/Methods/add.jsp</result>
    22 
    23         </action>
    24 
    25         <!-- 对应着MethodAction里面的edit方法 -->
    26 
    27         <action name="edit" class="org.lesson05.MethodAction"
    28 
    29 method="edit">
    30 
    31             <result name="success">/Methods/edit.jsp</result>
    32 
    33         </action>
    34 
    35         <!-- 对应着MethodAction里面的delete方法 -->
    36 
    37         <action name="delete"
    38 
    39 class="org.lesson05.MethodAction"
    40 
    41  method="delete">
    42 
    43             <result name="success">/Methods/delete.jsp</result>
    44 
    45         </action>
    46 
    47 </package>

    对应的MethodAction类,代码如下:
              

     1   importcom.opensymphony.xwork2.ActionSupport;
     2 
     3 public class MethodAction extends ActionSupport
     4 
     5 {
     6 
     7  
     8 
     9     @Override
    10 
    11     public String execute() throws Exception
    12 
    13     {
    14 
    15        return SUCCESS;
    16 
    17     }
    18 
    19    
    20 
    21     public String add() throws Exception
    22 
    23     {
    24 
    25        return SUCCESS;
    26 
    27     }
    28 
    29    
    30 
    31     public String edit() throws Exception
    32 
    33     {
    34 
    35        return SUCCESS;
    36 
    37     }
    38 
    39    
    40 
    41     public String delete() throws Exception
    42 
    43     {
    44 
    45        return SUCCESS;
    46 
    47     }
    48 
    49 }

               使用action的method属性可以任意指定处理请求的方法(只要该方法和execute

    方法具有相同的格式),这样就可以在同一个类中完成相关的任务,而不需要去编写不

    同的Action类。

               注意:Struts2在根据action元素的method属性查找方法时有两种途径:

               1.查找与method属性值完全一致的方法.
    2.查找doMethod()形式的方法.

       3.动态方法调用:

             另外一种无需配置就可以直接调用Action中的非execute方法的方式,是使用

    Struts2的动态方法调用。

       动态方法调用是在action的名字中使用感叹号(!)来标识要调用的方法名,其语法格

    式为 actionName!methodName.action

       例如,我们配置了如下的action

     

    1   <action name="user" class="org.lesson05.UserAction">
    2 
    3             <result name="success">/Methods/list.jsp</result>
    4 
    5    </action>

              当请求/user!delete.action时,就会自动调用UserAction中的delete()方

    提示,这种调用方式会带来安全隐患!

     

    4.模拟Struts1中的ForwardAction
                

    1  <action name="user">
    2 
    3        <result>/index.jsp</result>
    4 
    5               </action>

          这样写就可以了.

     

       5.默认的action

             如果请求一个不存在的action,结果将是HTTP404错误。在Struts2中,可以指定一个默认的action,如果一个请求没有其他的action匹配,那么默认的action将被执行。

             默认的action使用default-action-ref元素来声明,如下所示:

             

     1  <!-- 默认action -->
     2 
     3 <package name="defaultAction" namespace="/default"
     4 
     5 extends="struts-default">
     6 
     7         <default-action-ref name="error"></default-action-ref>    
     8 
     9         <action name="defaultaction"
    10 
    11 class="org.lesson05.DefaultAction">
    12 
    13             <result name="success">/defaultAction.jsp</result>
    14 
    15         </action>
    16 
    17         <action name="error">
    18 
    19             <result>/error.jsp</result>
    20 
    21         </action>
    22 
    23     </package>

       注意:根据struts-2.0.dtd中定义的package元素的内容模型,

    default-acion-ref必须在action元素之前使用。

       如果请求的是/default/defaultaction1.action,框架找不到映射到defaultaction1的action,那么名为error的action将被调用。

        注意:每个包中都可以有它自己默认的action,但是每一个名称空间应该只有一个默认action。如果具有相同名称空间的多个包中都声明了默认action,那么哪一个action才是默认的将无法保证。

        注意:默认action只对action的访问有效。如果你访问一个非action的资源,例如/user.jsp,而该页面不存在,这时仍会看到HTTP404错误。如果想为整个Web应用程序指定默认页面,需要在web.xml文件中对HTTP404错误指定相应的错误处理页面。

     

    6.通配符映射

          随着Web应用程序的增加,所需的Action也会更多,从而导致大量的action映射,使用通配符可以减少action配置的数量,使一些具有类似行为的Action或者Action方法可以使用通用的样式来配置。

          通配符即星号(*),用于匹配0个或多个字符,在配置action时,可以在action元素的name属性中使用星号(*)来匹配任意的字符。

                 以下是在action映射中使用通配符:
                  

    1  <action name="news*"          
    2 
    3 class="org.struts2.lesson05.News{1}Action">
    4 
    5                     <result name="success">/WEB-INF/News/{1}.jsp</result>
    6 
    7         </action>

          我们在action元素的name属性中使用了通配符(*),允许这个映射匹配所有以/news开始的URL,例如/newsAdd,/newsEdit,/newsDelete,但是,如果请求的是/newsEdit/add,那么这个映射就不会被匹配。

          在上面,有一个特殊的记号{1},这是作为占位符使用的,它将被通配符所匹配的值替换,例如访问/newsEdit,通配符(*)匹配的部分是Edit,那么,这个值将替换{1},最终调用的类是org.struts2.lesson05.NewsEditAction,Action

       执行成功后导向的结果页面是/WEB-INF/News/Edit.jsp

          在action映射和action结果中,通配符匹配的值可以用记号{N}来访问,N是从1到9的数字,指出替换的是哪一个通配符匹配的值。整个请求URL可以用记号{0}来访问。例如如下的action映射:
        

    1  <action name="*_*" class="org.struts2.lesson05.{1}Action"  
    2 
    3 method="{2}">
    4 
    5             <result>/WEB-INF/News/{0}.jsp</result>
    6 
    7         </action>

          当访问/News_delete时,name属性中的第一个”*”匹配News,第二个”*”匹配delete,class属性中使用的记号是{1},所以被News所替换,method属性中使用的记号是{2},于是被delete所替换。结果映射中使用的记号是{0},于是被整个URL替换,即News_delete所替换。整个替换后的结果是:当请求/News_delete时,框架调用NewsAction实例的delete方法对请求进行处理。执行成功后,请求被导向到/WEB-INF/News/News_delete.jsp页面。

          通配符方法设置的另一种常见方式是使用后缀通配符,即将”*”放在action名字的后面,在”*”和名字前缀之间使用一个特殊字符作为分隔,常用的特殊字符是下划线(_),当然也可以使用其他字符。例如:

              

    1      <action name="News_*"
    2 
    3 class="org.struts2.lesson05.NewsAction" method="{1}">
    4 
    5                     <result>/WEB-INF/News/{0}.jsp</result>
    6 
    7         </action>

           当请求/News_delete时,调用的是NewsAction实例的delete方法,当请求/News_edit的时候,调用的是NewsAction实例的edit方法。

     

  • 相关阅读:
    Spring Boot 使用 Dev-tool 热部署
    Spring Boot 上传文件
    Spring Boot 目录文件结构
    Spring MVC 文件上传
    Spring MVC 混合使用多种视图技术
    XmlViewResolver 和 ResourceBundleViewResolver
    XML 和 Json
    Excel 和 PDF
    04-树5 Root of AVL Tree (25 分)
    04-树4 是否同一棵二叉搜索树 (25 分)
  • 原文地址:https://www.cnblogs.com/XQiu/p/5086463.html
Copyright © 2011-2022 走看看