`
icyheart
  • 浏览: 779547 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

webwork中action result type

    博客分类:
  • J2EE
阅读更多
和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 
 
0
2
分享到:
评论

相关推荐

    WebWork_Result

    本文详细介绍了WebWork框架中`WebWork_Result`配置文件的使用方法,重点讲解了`dispatcher`和`redirect`两种类型的`result`配置及其区别。通过这些知识点的学习,可以帮助开发者更好地掌握WebWork框架的核心机制,...

    webwork配置详解

    总结来说,WebWork 配置涉及Action的创建、ActionContext的理解和使用、ServletDispatcher的调度机制,以及Action的测试和Result Type的设置。熟练掌握这些知识点,能够帮助开发者高效地构建和维护基于WebWork的Java...

    webwork入门(添加注释)

    ServletDispatcher会根据Action的结果类型(Result Type)选择合适的视图进行渲染。 **Action 的单元测试** WebWork支持对Action进行单元测试,通过模拟HTTP请求,可以独立地测试Action的业务逻辑。这有助于确保...

    WEBWORK

    `&lt;result&gt;` 子元素定义了 Action 执行成功后的跳转路径,`type="dispatcher"` 表示使用 Servlet 的 `RequestDispatcher` 进行页面跳转。 通过这样的配置,WebWork 可以根据请求参数找到对应的 Action,执行业务逻辑...

    webwork核心技术文档

    1. **Action(动作)**:Action是WebWork中的核心组件,它是业务逻辑与视图之间的桥梁。在WebWork中,Action类代表一个特定的用户操作,例如用户点击一个按钮或提交一个表单。当用户请求到达服务器时,WebWork会根据...

    WebWork完全教程.doc

    WebWork完全教程 ...本教程涵盖了 WebWork 框架的安装、Action、ActionContext、ServletDispatcher、单元测试、Result Type、EL 和 OGNL 等知识点,旨在帮助开发者快速掌握 WebWork 框架的使用和开发。

    webwork2个人学习总结

    - 在`&lt;action&gt;`节点中,定义了具体的Action,如`login`,并指定了Action类`com.webwork.Action.LoginAction`。 - `&lt;result&gt;`节点定义了Action执行后的结果,比如`success`和`input`。每个结果都有一个类型(`type`...

    WebWork入门例子 HelloWorld

    &lt;result type="dispatcher"&gt;/WEB-INF/views/hello.jsp&lt;/result&gt; &lt;/action&gt; ``` 这里的`hello`是URL中的Action名,`com.example.HelloWorldAction`是对应的Action类,`/WEB-INF/views/hello.jsp`则是Action执行后...

    webwork2教程

    &lt;result name="success" type="dispatcher"&gt;ex01-success.jsp&lt;/result&gt; &lt;/action&gt; ``` - **Action 配置**:这里定义了一个名为 `helloWebWorld` 的 Action,其实现类为 `lesson03.HelloWebWorldAction`。 - **...

    webwork的工作流程

    - Package 在WebWork中是一个配置单元,它包含了Action、Interceptor和Result的定义。`&lt;package&gt;`标签用于定义包,通过`name`属性标识,可选的`extends`属性用于继承其他包的配置。`namespace`属性用于指定包的命名...

    webwork 上传文件与下载文件 使用笔记

    3. **Action类中声明文件字段**:在对应的Action类中声明用于接收上传文件的字段,并提供对应的getter和setter方法。 ```java private File newfile; private String newfileContentType; private String ...

    webwork2.0参考资料

    - **定义**: Action是WebWork中的核心组件之一, 负责处理具体的业务逻辑, 类似于MVC模式中的Controller角色。 - **分类**: - Field-Driven Action: 基于字段驱动, 表单提交的数据直接映射到Action类的属性上。 - ...

    webwork简单实例及说明

    &lt;result type="dispatcher"&gt;/helloWorld.jsp&lt;/result&gt; &lt;/action&gt; ``` 最后,创建一个简单的JSP页面(`helloWorld.jsp`)显示消息: ```jsp &lt;h1&gt;&lt;s:property value="message"/&gt; ``` 当你通过浏览器访问`...

    webwork 控制反转小例子,配置文件的写法

    - 在WebWork中,依赖注入通常是通过在Action类中声明公共属性,并在配置文件中指定其值来实现的。例如,如果`MyAction`类有一个`UserService`的依赖,我们可以在配置文件中这样设置: ``` &lt;action name="myAction...

    webwork搭建步骤

    &lt;result name="success" type="dispatcher"&gt;/welcomeResult.jsp&lt;/result&gt; &lt;/action&gt; ``` 这个配置文件定义了一个名为`welcome`的动作,该动作对应于`com.action.WelcomeAction`类,并且成功执行后会跳转...

    webwork教程几原码示例

    5. **结果类型(Result Type)**: WebWork允许定义多种结果类型,如Redirect、Stream等,控制动作执行后的页面跳转或数据流输出。在`webwork-example`中,你可能看到不同结果类型的实例。 6. **表单和数据绑定**...

    剖析Webwork源码.pdf

    5. **Result**:定义如何处理Action执行后的结果,比如渲染JSP页面、生成PDF文件等。 6. **Configuration**:配置文件用于定义Action、拦截器、验证规则等信息,通常使用XML格式。 #### 架构演变与新特性 - **...

    使用webwork实现上传图片并显示

    在WebWork的配置文件(如`struts.xml`或`xwork.xml`)中,我们需要定义一个Action,用于处理上传请求。比如: ```xml &lt;action name="upload" class="com.example.UploadAction"&gt; &lt;result name="success"&gt;/show...

Global site tag (gtag.js) - Google Analytics