1.Struts2的属性驱动.

Struts2的属性驱动指的是在action中JSP页面的每一个form中的name都对应在action中有一个属性与之对应。看下面代码片段:

<form action="register.do" name="RegisterForm" method="post">

Username:<input type="text" name="uname"><br>
            Password:<input type="password" name="upass"><br>
            Confirm: <input type="password" name="rpass"><br>
            <input type="submit" value="Submit">

</form>

这是一个最基本的用户注册的表单,它有三个数据要提交: uname、upass、rpass,那么对应的Action也要有三个属性(其实是三个属性的setter),看register.do实际的Action定义类:

package org.abu.csdn.action.user;

import com.opensymphony.xwork2.ActionSupport;

/**
 * Struts2属性驱动演示用的Action
 * @author 阿布
 *
 */ 
public class RegisterAction extends ActionSupport {

private String uname;
    private String upass;
    private String rpass;

public String getUname() {
        return uname;
    }

public void setUname(String uname) {
        this.uname = uname;
    }

public String getUpass() {
        return upass;
    }

public void setUpass(String upass) {
        this.upass = upass;
    }

public String getRpass() {
        return rpass;
    }

public void setRpass(String rpass) {
        this.rpass = rpass;
    }
    
    @Override
    public String execute() throws Exception {        
        return ActionSupport.SUCCESS;
    }

}

你会看到RegisterAction中的三个属性和RegisterForm表单中的name属性名字一模一样,没错,这就是Struts2的属性驱动,当表单提交到RegisterAction后,Struts2将会自动将根据表单的name属性调用Action中相应的属性setter,去自动赋值。

2.Struts2的模型驱动

Struts2的模型驱动其实和Struts1.x中的ActionForm有点类似,在Struts1.x中每一个Action都必须有一个ActionForm与之对应,而Struts2.0中,每一个Action同样需要提供一个POJO对象,用来封装表单属性,看代码:

<form action="register.do" name="RegisterForm" method="post">

Username:<input type="text" name="uname"><br>
            Password:<input type="password" name="upass"><br>
            Confirm: <input type="password" name="rpass"><br>
            <input type="submit" value="Submit">

</form>

这段表单的代码和上面的一模一样,就不赘述了。接下来看POJO的代码,其实就是普通的Java Bean:

package org.abu.csdn.action.user;

import com.opensymphony.xwork2.ActionSupport;

/**
 * Struts2属性驱动演示用的Java Bean
 * @author 阿布
 *
 */ 
public class User {

private String uname;
    private String upass;
    private String rpass;

public String getUname() {
        return uname;
    }

public void setUname(String uname) {
        this.uname = uname;
    }

public String getUpass() {
        return upass;
    }

public void setUpass(String upass) {
        this.upass = upass;
    }

public String getRpass() {
        return rpass;
    }

public void setRpass(String rpass) {
        this.rpass = rpass;
    }
   
}

对不起,也是和属性驱动中的例子一样,很简单,因为演示的都是同一个例子,只是方法不同而已,但是接下来就不一样了,看RegisterAction代码:

package org.abu.csdn.action.user;

import org.abu.csdn.dto.User;

import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;

/**
 * Struts2模型驱动演示用的Action
 *  
 * @author 阿布
 *
 */ 
public class RegisterAction extends ActionSupport implements ModelDriven<User> {

private User user;
    
    public User getUser() {
        return user;
    }

public void setUser(User user) {
        this.user = user;
    }

@Override
    public String execute() throws Exception {        
        return ActionSupport.SUCCESS;
    }

// 模型驱动必须实现的方法,也是ModelDriven接口中唯一的方法 
    public User getModel() {
        
        return user;
    }

}

看到没有,和属性驱动的Action有很大的区别,下面一一列举:

(1)模型驱动的Action必须实现ModelDriven接口,而且要提供相应的泛型,这里当然就是具体使用的Java Bean了。

(2)实现ModelDriven的getModel方法,其实就是简单的返回泛型的一个对象。

(3)在Action提供一个泛型的私有对象,这里就是定义一个User的user对象,并提供相应的getter与setter。

好了,上面的三件事做完之后,Action就会去自动调用User的setter将表单中的name属性的值赋给User中的属性。而Action的后续处理的Jsp页面后者是Servlet就可以使用user对象了。

3.到底是用属性驱动和是模型驱动呢?

这个问题困扰了很多Struts2的初学者,我这里提供一些建议:

(1)请你统一整个系统中的Action使用的驱动模型,即要么都是用属性驱动,要么都是用模型驱动。

(2)如果你的DB中的持久层的对象与表单中的属性都是一一对应的话,那么就使用模型驱动吧,毕竟看起来代码要整洁得多。

(3)如果表单的属性不是一一对应的话,那么就应该使用属性驱动,否则,你的系统就必须提供两个Bean,一个对应表单提交的数据,另一个用与持久层。

看上面的例子,其实密码确认rpass是不需要放到DB中去的,而仅仅是用于校验密码的,不是吗?那么如果使用模型驱动的话,就存在这个问题了,而使用属性驱动的话又有些繁琐,现在我们就来调整一个看我的解决方法:

4.完整的例子

(1)表单提交的JSP页面index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme() + "://"
            + request.getServerName() + ":" + request.getServerPort()
            + path + "/";
%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <base href="<%=basePath%>">
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>CSDN首页</title>
    </head>
    <body>
        <s:a href="userManager/userRegister.jsp">用户注册</s:a>
        
        <form action="register.do" name="SampleForm" method="post">
            Username:<input type="text" name="uname"><br>
            Password:<input type="password" name="upass"><br>
            Confirm: <input type="password" name="rpass"><br>
            <input type="submit" value="Submit"> 
        </form>
    </body>
</html>

(2)User的定义

package org.abu.csdn.action.user;

import com.opensymphony.xwork2.ActionSupport;

/**
 * Struts2属性驱动演示用的Java Bean
 * @author 阿布
 *
 */ 
public class User {

private String uname;
    private String upass;

public String getUname() {
        return uname;
    }

public void setUname(String uname) {
        this.uname = uname;
    }

public String getUpass() {
        return upass;
    }

public void setUpass(String upass) {
        this.upass = upass;
    }   
   
}

(3)RegisterAction的定义

package org.abu.csdn.action.user;

import com.opensymphony.xwork2.ActionSupport;

/**
 * Struts2属性驱动演示用的Action
 * @author 阿布
 *
 */ 
public class RegisterAction extends ActionSupport {

// 用来给spring注入,及属性拷贝

private User user;

private String uname;
    private String upass;
    private String rpass;

public String getUname() {
        return uname;
    }

public void setUname(String uname) {
        this.uname = uname;
    }

public String getUpass() {
        return upass;
    }

public void setUpass(String upass) {
        this.upass = upass;
    }

public String getRpass() {
        return rpass;
    }

public void setRpass(String rpass) {
        this.rpass = rpass;
    }
    
    @Override
    public String execute() throws Exception {

// 调用方法将属性copy到user中去,便于后续的service方法

copyAttribute();

// TODO:编写自己的user业务代码 
        return ActionSupport.SUCCESS;
    }

/**
     * 注意这是一个action全局的校验
     */ 
    @Override
    public void validate() {
        // 进行密码的校验 
        if (!(upass.trim()).equals((rpass.trim()))) {
            // 注意这里addFieldError的fieldName参数必须用引号引起来,
            // 不能这样使用addFieldError(rpass,"XXXXXX"),而必须是addFieldError("rpass","XXXXX") 
            this.addFieldError("rpass", this
                    .getText("csdn.action.user.register.validate.verify"));
        }
    }

/**
     * 将表单属性中需要持久化的属性拷贝到user中去
     * @author 阿布
     *
    */ 
    private void copyAttributes () {

user.setUname(uname);

user.setUpass(upass);

}

}

(4)Struts.xml配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
    "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
    <package name="root" extends="struts-default" namespace="/userManager">
        <action name="userRegister" class="org.abu.csdn.action.user.RegisterAction">
            <result name="success">/index.jsp</result>
            <result name="input">/userManager/userRegister.jsp</result>
        </action>                
    </package>
</struts>

原文:http://blog.csdn.net/csuliky/archive/2009/05/30/4226917.aspx

Struts2的属性驱动与模型驱动的区别的更多相关文章

  1. action类中属性驱动和模型驱动的区别

    1.Struts2的属性驱动 在Action类中,属性××通过get××()和set××()方法,把参数在整个生命周期内进行传递,这就是属性驱动 代码如下: package org.abu.csdn. ...

  2. Struts2中属性驱动与模型驱动

    属性驱动: 1.概念 能够利用属性驱动获取页面表单元素的内容 2.步骤 1.在action中声明属性,属性的名称和页面元素中name属性的值保持一致 2.action中的属性必须有set和get方法 ...

  3. Struts2(四)属性驱动和模型驱动

    一.概述 所谓模型驱动,就是使用单独的JavaBean实例贯穿整个MVC流程,与之相对应的属性驱动方式,则使用属性作为贯穿MVC流程的信息携带者.属性无法独立存下,它必须依附于一个对象,这个对象就是A ...

  4. Struts2属性驱动与模型驱动

    为什么要使用属性驱动和模型驱动 struts2与struts很大的不同点在于,struts的execute方法提供了HttpServletRequest和HttpServletResponse方法在获 ...

  5. strus2中获取表单数据 两种方式 属性驱动 和模型驱动

    strus2中获取表单数据 两种方式 属性驱动 和模型驱动 属性驱动 /** * 当前请求的action在栈顶,ss是栈顶的元素,所以可以利用setValue方法赋值 * 如果一个属性在对象栈,在页面 ...

  6. Struts2 属性驱动、模型驱动、异常机制

    模型驱动使用单独的VO(值对象)来封装请求参数和处理结果,属性驱动则使用Action实例来封装请求参数和处理结果. 一.使用模型驱动 1.login.action采用模型驱动模式实现,采用模型驱动时必 ...

  7. struts2 中属性驱动(其实就是struts2 action 中处理 request 的参数【old 方式servlet api 封装数据到javabean中(or beanutils)】),这里属性驱动是新方式

    1.属性驱动 a\  一般的set public class UserAction extends ActionSupport { private String username; private S ...

  8. Struts2的学习-属性驱动和模型驱动

    1.新建空项目,并托管到码云 2.设立maven 3.设置pom.xml 4.建包 5.在java包里建立两个类 package com.nf.entity; public class User { ...

  9. struts2属性驱动模型

    属性驱动模型的作用: 因为struts2与servlet API 实现了解耦,无法直接使用HttpServlet Request对象获取表单提交的参数,但Struts2提供了属性驱动模型机制来解决这个 ...

随机推荐

  1. SQL Server优化技巧之SQL Server中的"MapReduce"

    日常的OLTP环境中,有时会涉及到一些统计方面的SQL语句,这些语句可能消耗巨大,进而影响整体运行环境,这里我为大家介绍如何利用SQL Server中的”类MapReduce”方式,在特定的统计情形中 ...

  2. Dynamic CRM 2013学习笔记(十七)JS读写各种类型字段方法及技巧

    我们经常要对表单里各种类型的字段进行读取或赋值,下面列出各种类型的读写方法及注意事项: 1. lookup 类型 清空值 var state = Xrm.Page.getAttribute(" ...

  3. 大话JS面向对象之扩展篇 面向对象与面向过程之间的博弈论(OO Vs 过程)------(一个简单的实例引发的沉思)

    一,总体概要 1,笔者浅谈 我是从学习Java编程开始接触OOP(面向对象编程),刚开始使用Java编写程序的时候感觉很别扭(面向对象式编程因为引入了类.对象.实例等概念,非常贴合人类对于世间万物的认 ...

  4. 基于 IdentityServer3 实现 OAuth 2.0 授权服务数据持久化

    最近花了一点时间,阅读了IdentityServer的源码,大致了解项目整体的抽象思维.面向对象的重要性; 生产环境如果要使用 IdentityServer3 ,主要涉及授权服务,资源服务的部署负载的 ...

  5. 安装时出现 Runtiem error (at 62:321) SWbem Locator:服务不存在,或已被标记为删除 该怎么解决?

    这是由wmi服务损坏引起的错误 修复WMI服务损坏的批处理程序 将下列代码复制到一个文本文件中,改名为fixwmi.bat,运行即可.需要一段时间,请大家耐心等候. ================= ...

  6. ajaxSubmit与ajaxFileUpload的空值

    ajaxSubmit发现正文无内容, ajaxFileUpload发现无上传内容, 嗯,你只是忘记了 html 中控件的 name 没有指定,这哥们不认 id 的.

  7. Mathematica修改默认字体

    1. 打开Option Inspector 2. 第一个下拉框选择Global Preference, 搜索stylehints 3. 修改字体为想要换的字体FamilyName, 比如换成苹果黑体 ...

  8. Qt之课外实践——文件操作(简单清道夫)

    说明:这个小项目是关于文件操作的.主要的功能有:重复文件的查找(根据文件的大小),说白了,就是讲大小相同的文件在一起显示出来,供用户自由的选择删除.这个360云盘里的文件去重还差的很远.还有空文件夹的 ...

  9. Atitit。如何实现dip, di ,ioc ,Service Locator的区别于联系

    Atitit.如何实现dip, di ,ioc  ,Service Locator的区别于联系 1. Dip原则又来自于松耦合思想方向1 2. 要实现dip原则,有以下俩个模式1 3. Ioc和di的 ...

  10. atitit. 浏览器插件 控件 applet 的部署,签名总结 浏览器 插件 控件 的签名安全机制o9o

    atitit. 浏览器插件 控件   applet 的部署,签名总结 浏览器 插件 控件 的签名安全机制o9o 1. 服务器部署签名 1 2. 签名流程::生成密钥..导出cert正书,签名 1 3. ...