和Webwork1.x不同,Webwork2的Action执行完后,其Result对应一个 Result Type,而这个Result Type完全可以根据具体应用或环境自己进行 定义,只需实现com.opensymphony.xwork.Result接口。Result Type使得Action的执行结果表现形式可以灵活多变!下面这会举例说明,这里先看看Webwork2提供的几种Result Type的定义,该定义在webwork-default.xml中,xwork.xml文件包含了该文件,自定义的Result Type可以直接写在 xwork.xml中:
<result-types>
<result-type name="dispatcher" class="com.opensymphony.webwork.dispatcher.ServletDispatcherResult" default="true"/>
<result-type name="redirect" class="com.opensymphony.webwork.dispatcher.ServletRedirectResult"/>
<result-type name="velocity" class="com.opensymphony.webwork.dispatcher.VelocityResult"/>
<result-type name="chain" class="com.opensymphony.xwork.ActionChainResult"/>
<result-type name="xslt" class="com.opensymphony.webwork.views.xslt.XSLTResult"/>
<result-type name="jasper" class="com.opensymphony.webwork.views.jasperreports.JasperReportsResult"/>
<result-type name="freemarker" class="com.opensymphony.webwork.views.freemarker.FreemarkerResult"/>
</result-types>
其大多都有location和parse两个参数,location指明action执行后接着去哪里,parse指明是否对location进行OGNL表达式解析。
1) dispatcher
action执行完后,请求会导向对应的View,Webwork2幕后其实是用RequestDispatcher来处理的,所以原 Request/Response对象会接着传递,原Request中的Atrributes不会丢失,这点与下面的redirect是不同的。
2) redirect
对上次的响应将重定向到指定的位置,redirect是重新产生一个新的Request,原来Request保存的东西将不再有效,比如不能通过requet.getAtrribute 取得原来set的对象,也不能取得action的实例,errors,field errors等,因为Action是建立在Single-thread model上的。
3) chain
action链,特殊的View调用方式,一个action执行完接着调用另一个action。有个必须的参数actionName,指明紧接着调用的另一action对象。如:
<result name="success" type="chain">
<param name="actionName">bar</param>
<param name="namespace">/foo</param>
</result>
执行后接着调用下面的action:
<action name="bar" class="myPackage.barAction">
...
</action>
4) velocity
5) freemarker
6) jasperreports
7) xslt
以上都是用不同技术的产生不同的View。
下面我举个自定义Result Type的示例,假如我有个Action testSendmail,根据处理结果将给指用户发送一份email。自定义一个Result Type,实现Result接口。
com.mycompany.webwork.example.SendmailResult
有三个必须参数:from ,to, subject,一个可选参数 body。
在xwork.xml中定义如下:
<result-types>
<result-type name="sendmail" class="com.mycompany.webwork.example.SendmailResult"/>
</result-types>
action定义:
<action name="testSendmail" class="com.mycompany.webwork.example.TestSendMailAction">
<result name="success" type="sendmail">
<param name="from">root@sina.com</param>
<param name="to">user@sina.com</param>
<param name="subject">hello,webwork!</param>
</result>
<result name="error" type="dispatcher">
<param name="location">error.jsp</param>
</result>
</action>
SendmailResult.java
package com.opensymphony.webwork.example;
import com.opensymphony.xwork.ActionInvocation;
import com.opensymphony.xwork.Result;
public class SendmailResult implements Result {
private String to;
private String from;
private String subject;
private String body;
public void execute(ActionInvocation invocation) throws Exception {
//TODO 实现Email发送部分
System.out.println("sending mail....");
System.out.println(" To:" + to);
System.out.println(" From:" + from);
System.out.println("Subject:" + subject);
}
public String getBody() {
return body;
}
public void setBody(String body) {
this.body = body;
}
public String getFrom() {
return from;
}
public void setFrom(String from) {
this.from = from;
}
public String getSubject() {
return subject;
}
public void setSubject(String subject) {
this.subject = subject;
}
public String getTo() {
return to;
}
public void setTo(String to) {
this.to = to;
}
}
写个简单的测试Action:
package com.opensymphony.webwork.example;
import com.opensymphony.xwork.ActionSupport;
public class TestSendMailAction extends ActionSupport {
public String execute() throws Exception {
return SUCCESS;
}
}
测试jsp,把它放在webwork-example/下:
testsendmail.jsp
<%@ taglib prefix="ww" uri="webwork" %>
<html>
<head><title>Test sendmail restul type</title></head>
<body>
<form action="testSendmail.action">
<input type="Submit" value="Submit"/>
</form>
</body>
</html>
打开http://localhost:8080/webwork-example/testsendmail.jsp,提交页面,控制台输出:
sending mail....
To:user@sina.com
From:root@sina.com
Subject:hello,webwork
分享到:
相关推荐
本文详细介绍了WebWork框架中`WebWork_Result`配置文件的使用方法,重点讲解了`dispatcher`和`redirect`两种类型的`result`配置及其区别。通过这些知识点的学习,可以帮助开发者更好地掌握WebWork框架的核心机制,...
总结来说,WebWork 配置涉及Action的创建、ActionContext的理解和使用、ServletDispatcher的调度机制,以及Action的测试和Result Type的设置。熟练掌握这些知识点,能够帮助开发者高效地构建和维护基于WebWork的Java...
ServletDispatcher会根据Action的结果类型(Result Type)选择合适的视图进行渲染。 **Action 的单元测试** WebWork支持对Action进行单元测试,通过模拟HTTP请求,可以独立地测试Action的业务逻辑。这有助于确保...
`<result>` 子元素定义了 Action 执行成功后的跳转路径,`type="dispatcher"` 表示使用 Servlet 的 `RequestDispatcher` 进行页面跳转。 通过这样的配置,WebWork 可以根据请求参数找到对应的 Action,执行业务逻辑...
1. **Action(动作)**:Action是WebWork中的核心组件,它是业务逻辑与视图之间的桥梁。在WebWork中,Action类代表一个特定的用户操作,例如用户点击一个按钮或提交一个表单。当用户请求到达服务器时,WebWork会根据...
WebWork完全教程 ...本教程涵盖了 WebWork 框架的安装、Action、ActionContext、ServletDispatcher、单元测试、Result Type、EL 和 OGNL 等知识点,旨在帮助开发者快速掌握 WebWork 框架的使用和开发。
- 在`<action>`节点中,定义了具体的Action,如`login`,并指定了Action类`com.webwork.Action.LoginAction`。 - `<result>`节点定义了Action执行后的结果,比如`success`和`input`。每个结果都有一个类型(`type`...
<result type="dispatcher">/WEB-INF/views/hello.jsp</result> </action> ``` 这里的`hello`是URL中的Action名,`com.example.HelloWorldAction`是对应的Action类,`/WEB-INF/views/hello.jsp`则是Action执行后...
<result name="success" type="dispatcher">ex01-success.jsp</result> </action> ``` - **Action 配置**:这里定义了一个名为 `helloWebWorld` 的 Action,其实现类为 `lesson03.HelloWebWorldAction`。 - **...
- Package 在WebWork中是一个配置单元,它包含了Action、Interceptor和Result的定义。`<package>`标签用于定义包,通过`name`属性标识,可选的`extends`属性用于继承其他包的配置。`namespace`属性用于指定包的命名...
3. **Action类中声明文件字段**:在对应的Action类中声明用于接收上传文件的字段,并提供对应的getter和setter方法。 ```java private File newfile; private String newfileContentType; private String ...
- **定义**: Action是WebWork中的核心组件之一, 负责处理具体的业务逻辑, 类似于MVC模式中的Controller角色。 - **分类**: - Field-Driven Action: 基于字段驱动, 表单提交的数据直接映射到Action类的属性上。 - ...
<result type="dispatcher">/helloWorld.jsp</result> </action> ``` 最后,创建一个简单的JSP页面(`helloWorld.jsp`)显示消息: ```jsp <h1><s:property value="message"/> ``` 当你通过浏览器访问`...
- 在WebWork中,依赖注入通常是通过在Action类中声明公共属性,并在配置文件中指定其值来实现的。例如,如果`MyAction`类有一个`UserService`的依赖,我们可以在配置文件中这样设置: ``` <action name="myAction...
<result name="success" type="dispatcher">/welcomeResult.jsp</result> </action> ``` 这个配置文件定义了一个名为`welcome`的动作,该动作对应于`com.action.WelcomeAction`类,并且成功执行后会跳转...
5. **结果类型(Result Type)**: WebWork允许定义多种结果类型,如Redirect、Stream等,控制动作执行后的页面跳转或数据流输出。在`webwork-example`中,你可能看到不同结果类型的实例。 6. **表单和数据绑定**...
5. **Result**:定义如何处理Action执行后的结果,比如渲染JSP页面、生成PDF文件等。 6. **Configuration**:配置文件用于定义Action、拦截器、验证规则等信息,通常使用XML格式。 #### 架构演变与新特性 - **...
在WebWork的配置文件(如`struts.xml`或`xwork.xml`)中,我们需要定义一个Action,用于处理上传请求。比如: ```xml <action name="upload" class="com.example.UploadAction"> <result name="success">/show...