Struts2配置详情

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的类型转换的完整类名

例如:
<action name="user" class="org.lesson05.UserAction">

<result name="success">/user.jsp</result>

</action>

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

<package name="methods" namespace="/"

extends="struts-default">

<!-- 对应着MethodAction里面的execute方法 -->

<action name="list" class="org.lesson05.MethodAction">

<result name="success">/Methods/list.jsp</result>

</action>

<!-- 对应着MethodAction里面的add方法 -->

<action name="add" class="org.lesson05.MethodAction"

method="add">

<result name="success">/Methods/add.jsp</result>

</action>

<!-- 对应着MethodAction里面的edit方法 -->

<action name="edit" class="org.lesson05.MethodAction"

method="edit">

<result name="success">/Methods/edit.jsp</result>

</action>

<!-- 对应着MethodAction里面的delete方法 -->

<action name="delete"

class="org.lesson05.MethodAction"

method="delete">

<result name="success">/Methods/delete.jsp</result>

</action>

</package>

对应的MethodAction类,代码如下:
            importcom.opensymphony.xwork2.ActionSupport;

public class MethodAction extends ActionSupport

{

@Override

public String execute() throws Exception

{

return SUCCESS;

}

public String add() throws Exception

{

return SUCCESS;

}

public String edit() throws Exception

{

return SUCCESS;

}

public String delete() throws Exception

{

return SUCCESS;

}

}

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

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

同的Action类。

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

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

3.动态方法调用:

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

Struts2的动态方法调用。

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

式为 actionName!methodName.action

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

<action name="user" class="org.lesson05.UserAction">

<result name="success">/Methods/list.jsp</result>

</action>

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

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

4.模拟Struts1中的ForwardAction
             <action name="user">

<result>/index.jsp</result>

</action>

这样写就可以了.

5.默认的action

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

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

<!-- 默认action -->

<package name="defaultAction" namespace="/default"

extends="struts-default">

<default-action-ref name="error"></default-action-ref>

<action name="defaultaction"

class="org.lesson05.DefaultAction">

<result name="success">/defaultAction.jsp</result>

</action>

<action name="error">

<result>/error.jsp</result>

</action>

</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映射中使用通配符:
               <action name="news*"

class="org.struts2.lesson05.News{1}Action">

<result name="success">/WEB-INF/News/{1}.jsp</result>

</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映射:
     <action name="*_*" class="org.struts2.lesson05.{1}Action"

method="{2}">

<result>/WEB-INF/News/{0}.jsp</result>

</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名字的后面,在”*”和名字前缀之间使用一个特殊字符作为分隔,常用的特殊字符是下划线(_),当然也可以使用其他字符。例如:

<action name="News_*"

class="org.struts2.lesson05.NewsAction" method="{1}">

<result>/WEB-INF/News/{0}.jsp</result>

</action>

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

时间: 2024-12-28 04:22:11

Struts2配置详情的相关文章

Struts2 配置

Struts2 配置 1.首先建立一个Web Project 2.将struts提供的jar包,放到lib目录下(添加必须要使用的,额外的不加,防止出现问题) 必须使用的jar包: commons-fileupload-  .jar(处理文件上传的) commons-io-  .jar(上面的依赖于这个) commons-logging-  .jar(日志处理) ognl-  .jar(表达式语言) struts2-core-  .jar() xwork-core- .jar(struts的内核

【SSH2(理论篇)】--Struts2配置详解

上篇博客讨论了SSH2框架模型,在开发过程中发现SSH2的开发模型其实类似于经典的三层模式,在每一层中分别添加了不同的框架,显示层使用的是Struts2进行配置的,业务逻辑层使用的是Spring配置,数据持久层则采用的是Hibernate,开发模式简单易懂,接下来将会分别从三层着手讨论每一层的运行内容. 一.Struts体系简介 struts,是Apache软件基金会(ASF)赞助的一个开源项目,它通过采用Java Servlet/JSP技术,实现了基于Java EE Web应用的Model-V

Struts2配置细节

struts.xml中 action中配置 如果是返回到网页则 /AA/XX.jsp 如果是返回到action则看namespace然后传参数,如果是同一个namespace则直接写上返回的action的名字 从action传action有两种方式 一种是 type="chain" 1 <package name="p1" namespace="/namespace1" extends="struts-default"&

STRUTS2配置动态页面

CreateTime--2017年5月11日09:00:31Author:Marydon 1.struts配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/

OpenNebula config配置详情

AUTH_MAD=AUTHN=ssh,x509,ldap,server_cipher,server_x509,EXECUTABLE=one_auth_mad DATASTORE_BASE_PATH=/app/opennebula/var//datastores DATASTORE_CAPACITY_CHECK=yes DATASTORE_LOCATION=/var/lib/one/datastores DATASTORE_MAD=ARGUMENTS=-t 15 -d dummy,fs,vmfs,

struts2配置中Action的name 和package的name和namespace作用

struts2配置中Action的name 和package的name和namespace是什么作用 在struts2 struts.xml 配置中  <package name="ajax" extends="json-default" namespace="/json">           <action name="ajaxLogin" class="com.rg.email.action.

深入Struts2配置元素

本章重点描述了一下struts拦截器的使用,文章的前面顺带介绍了一下struts的Bean配置.常量配置和包配置 1.Bean配置 Struts2是一个高度可拓展的框架,框架大部分核心组件都是以配置的方式写在配置文件中的,当开发者需要替换其核心组件的时候,只需要写好自己的实现类, 然后配置到配置文件中.我们打开struts2-core-2.x.x.jar文件,打开里面的struts-default.xml文件,看到该文件配置了大量的Bean定义,该配置文件部分 代码如下所示: <!-- 下面是s

MyEclipse下struts2配置使用和Ajax、json的配合

原创文章,转载请注明:MyEclipse下struts2配置使用和Ajax.json的配合 新手,初学struts2的配置,同时尝试与Ajax通过json交互.首先介绍MyEclipse下struts2的配置. 1.struts2的配置 右键项目,MyEclips->project facets->install apache struts(2.x)facets URL pattern我选择了*.action,libraries只选择了core 1.1撰写action 新建package,名为

脚本查询网络接口的配置详情

在学习网络基础的过程中,每次查询网络配置接口,都要输入一大段,于是突发奇想,写一个脚本,来实现查询,下面附上这次的创作过程.   思路:1.列出当前可选择的接口,提示用户选择         2.如果选择错误,则提醒"wrong choice",并且让用户重新选择:如果选择正确则列出该接口的详细配置详情:如果输入{q|Q},则退出脚本. 仅取出网络接口名称,下一步准备写入代码,显示网络接口详情 执行成功! 代码附上    过程反思:    期间遇到过,脚本执行错误的情况,发现输入错误接