1. web.xml
此文件的配置可以参看struts2的示例文档 <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter><filter-mapping>
<filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping><welcome-file-list>
<welcome-file>index.html</welcome-file> </welcome-file-list> 2. Action: 业务处理器,调用相应的Model类实现业务处理,返回结果。 实际开发中,Action类通常继承自 struts2提供的 com.opensymphony.xwork2.ActionSupport 类,以便简化开发。 开发完后需要配置 struts2.xml文件<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"><struts>
<package name="default" namespace="/" extends="struts-default"> <action name="hello" class="com.opensymphony.xwork2.ActionSupport"> <!-- 结果为 success 时, 跳转到 hello.jsp页面 (dispatcher 转发) --> <result name="success">hello.jsp</result> <!-- 结果为 tutorial 时, 重定向到 /tutorial/test.action (forward 重定向) --> <result name="tutorial" type="redirect">/tutorial/test.action</result> <!-- 结果为 tutorial2 时, 重定向到test.action --> <result name="tutorial2" type="redirectAction">/tutorial/test.action</result> </action> </package></struts>3. Result
实现视图的调用,并决定视图以那些形式展现给客户端。【Struts的执行过程】
3.1 当Web容器接受到请求后,将强求交给 web.xml 中配置的 struts2 框架的控制器StrutsPrepareAndExecuteFilter (核心控制器) 3.2 由 StrutsPrepareAndExecuteFilter 确定请求对应的 Action (业务控制器) 3.3 框架根据 Action 返回的结果字符串,由 StrutsPrepareAndExecuteFilter (核心控制器)选择对应的result, 将结果呈现给用户。 4. Struts 2 的配置器- 4.1 struts.xml
3)package元素
name 属性为必须得并且是唯一的,用来指定包的名称 extends 属性类似Java的extends,指定用来扩展的包 namespace 属性可选。namespace="/"代表根目录, namespace=""默认命名空间 通常会使用模块名称命名请求路径先查询命名空间下的,如果没有在查找默认空间下的。
例如请求URL为 /myspace/somespace/some.action。 它先查找的命名空间是 /myspace/somespace/ 下- 4.2 struts-default.xml : Struts2框架的默认配置文件。
- 4.3 struts-plugin.xml : 是struts2插件使用的配置文件。
- 5.1 Action 作用:为给定的请求封装需要做的实际工作(调用特定的业务处理类)
为数据转移提供场所
帮助框架觉得由那个结果呈现请求响应 Action接受参数: 1) 属性名 2) JavaBean 3) ModelDriven i: 定义实体类,为实体添加属性以及setter和getter i: 创建Action实现ModelDriven接口,重写方法getModel() i: Action中要提供JavaBean类型的属性,需要实例化,但不需要相应的setter和getter方法 i: Form 表单项的name属性以及页面取值时通过 <s:property value="属性名" />的形式- 5.2 method 属性:
<action name="student" class="org.zm.test.studentAction" method="Show">
<result name="success">no.jsp</result> </action>当调用student.action时, 执行 rg.zm.test.studentAction 类 的 Show()方法。
method属性解决多个页面调用同一个action类的问题,减少action的数据。例如用户登录,用户注册都调用同一个action, userAction 。 分别调用这个类中的 Login方法和 Register 方法。
提示: Struts2根据action元素的method属性查找执行方法时有两种途径。1.查找与method属性值完全一致的方法。 2.查找domethod()形式的方法。【login() / doLogin()】
- 5.3 Action中动态方法调用 : 目的 减少Action的数量。
动态方法调用(Dynamic Method Invocation, MDI) 是指表单元素的 Action 并不是直接等于某个Action的名称,而是通过在Action的名称中使用感叹号(!)来标识要调用的方法名称,格式为 actionName!methodName.action。
<action name="student" class="org.zm.test.studentAction" > <result name="login">manager.jsp</result> <result name="register">success.jsp</result> ...... </action> 当请求 student!login.action 时, 框架将调用 studentAction的login()方法; 当请求 student!register.action 时, 框架将调用 studentAction的register()方法;提示:考虑到安全问题,通常禁止调用动态方法。
- 5.4 Action 中通配符的使用
<action name="*User" class="org.zm.test.studentAction" method="{1}">
<result name="login">/page/{1}.jsp</result> <result name="register">/page/{1}.jsp</result> ...... </action>在action的name属性中使用星号, 允许这个 Action 匹配所有以 User 结束的URL。 如 loginUser.action。 配置该action元素时,还制定了method属性,该属性使用一个表达式{1},该表达式的值就是name属性值的第一个"*"的值。 {1} = login
- 5.5 配置默认的 Action
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <package name="default" extends="struts-default"> <default-action-ref name="defaultAction"></default-action-ref> <action name = "defaultaction" > <result>error.jsp</result> </action> </package> </struts>6. Result的配置
- 6.1 常用结果类型
1. dispatcher 类型: Action 默认的结果类型, 采用转发的形式请求指定的视图资源,请求中的数据信息不会丢失。
2. redirect 类型:采用重定向的方式请求指定的视图资源, 通过 HttpServletResponse 对象的 sendRedirect()方法重新生成一个请求,原请求中的数据信息会丢失。 3. redirectAction 类型: 采用重定向的方式请求一个新的Action,,原请求中的数据信息会丢失。- 6.2 动态结果
配置的时候不知道执行那个,在运行时才能知道哪个结果作为视图显示给用户。即在配置时使用表达式,在运行时,由框架根据表达式的值来确定要使用哪个结果。
-
- 1. SchoolAction
import com.opensymphony.xwork2.ActionSupport;
public class SchoolAction extends ActionSupport{ private String nextDispose; private User objUser;//省略get set
public String Login(){
if(objUser.getName().equals("zm")){ nextDispose = "teacher"; }else { nextDispose = "student"; } return SUCCESS; } }2. struts.xml文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <!-- 创建一个default包,继承自Struts2的struts-default包 --> <package name="default" namespace="/" extends="struts-default"> <action name="school" class="org.zm.test.SchoolAction" method="Login"> <result type="redirectAction" name="success">${nextDispose}</result> <result name="error">Register.jsp</result> </action> <action name="teacher" class="org.zm.test.teacherAction" method="Show"> <result name="success">ok.jsp</result> </action> <action name="student" class="org.zm.test.studentAction" method="Show"> <result name="success">no.jsp</result> </action> </package> </struts>提示:配置动态结果的时候 ${nextDispose} 可能会出错,解决方案:
Window -- Preferences -- MyEclipse -- Validation - Validator 行 Build列的复选框上的勾去掉。 7. 全局结果 全局结果在所有的Action都可以共享这个结果。 如果 result 中的名称和全局结果的 result名称相同,会执行局部的 action, 当找不到对象的名称时才会去寻找全局结果并执行。<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"><struts> <!-- 创建一个default包,继承自Struts2的struts-default包 --> <packag<global-results> <result name="error">/page/error.jsp</result> <result name="login" type="redirect">/page/login.jsp</result> </global-results> </package></struts> 8. struts2 设置成开发模式在struts.xml中增加:<constant name="struts.devMode" value="true" />