时间:2017-1-11 11:05

——Struts2中获取请求参数(重点)

1、Struts2是一个MVC框架,那么分别表示什么?
    View:JSP
    Model:Action
    Controller:Action、StrutsPrepareAndExecuteFilter

2、为什么Action既是Model又是Controller?
    因为Action本身可以作为一个JavaBean。

3、在Struts2中获取请求参数有两大种(三小种)方式可以获取:
    1)属性驱动(在Action中添加属性,对Action的属性进行操作)
        *   直接将Action作为一个Model,就可以得到请求参数,也就是将Action作为一个JavaBean,提供get/set方法。
            这种方式底层是通过反射来实现的。
            >   问题1:使用Action封装请求参数,会不会存在线程安全问题?
                不会,每一次请求都会生成一个Action对象。
            >   问题2:使用该方式封装数据,将数据封装到Action属性中,不可能将Action对象传递给业务层。
                需要单独定义JavaBean,将Action属性封装到JavaBean

            示例代码:

                    //属性驱动的第一种方式获取请求参数,直接将Action做为Model
                    public class Login1Action extends ActionSupport {
 
                        private String username;
                        private String password;
 
                        public String getUsername() {
                            return username;
                        }
 
                        public void setUsername(String username) {
                            this.username = username;
                        }
 
                        public String getPassword() {
                            return password;
                        }
 
                        public void setPassword(String password) {
                            this.password = password;
                        }
 
                        @Override
                        public String execute() throws Exception {
                            HttpServletRequest request = ServletActionContext.getRequest();
 
                            if ("tom".equals(username) && "123".equals(password)) {
 
                                request.getSession().setAttribute("username", username);
 
                              return SUCCESS;
                            } else {
                                request.setAttribute("login.message", "用户名或密码错误");
                                return "failer";
                            }
                        }
                    }

            实现原理:
                1、首先为Action类提供JavaBean属性,并提供get / set方法
                2、在过滤器中添加如下代码,将请求参数封装到JavaBean中:

                    /*
                     * 在调用invoke()方法前,处理请求参数的封装
                     */
                    Object actionObject = c.newInstance();
                    // 将请求参数封装到Action中(底层也是反射实现的)
                    BeanUtils.populate(actionObject, request.getParameterMap());
                3、在Action中使用属性 

------------------------------------------------------------------------------------------------------------------

        *   创建独立的Model对象,页面通过ognl表达式封装
            >   在Action中声明一个JavaBean对象
            >   private User user;
            >   提供get/set方法:public User getUser()....
            >   在页面中使用ognl表达式:<input type="text" name="user.username" />
            优点:简单,解决了第一种封装的问题。
            缺点:在页面中使用了ognl表达式,与Struts2框架耦合度高。

            示例代码:

                /*

                 * 属性驱动的第二种方式获取请求参数,在Action中声明一个JavaBean
                 * 在表单中的name值需要修改为:
                 *  * name="user.username" name="user.password"
                 *  * <input type="text" name="user.username" />
                 * user表示Action内部封装JavaBean对象的名称
                 * 这是Struts2中提供的一个默认表达式语言:ognl
                 */
                public class Login2Action extends ActionSupport {
                    private User user;
 
                    public User getUser() {
                        return user;
                    }
 
                    public void setUser(User user) {
                        this.user = user;
                    }
 
                    @Override
                    public String execute() throws Exception {
                        HttpServletRequest request = ServletActionContext.getRequest();
 
                        if ("tom".equals(user.getUsername()) && "123".equals(user.getPassword())) {
 
                            request.getSession().setAttribute("username", user.getUsername());
                            return SUCCESS;
                        } else {
                            request.setAttribute("login.message", "用户名或密码错误");
                            return "failer";
                        }
                    }
                }

------------------------------------------------------------------------------------------------------------------

            这种方式底层通过Struts2中的一个interceptor进行了封装:
                <interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor" />
                    @Override

                    public String doIntercept(ActionInvocation invocation) throws Exception {
                        Object action = invocation.getAction();
                        if (!(action instanceof NoParameters)) {
                            ActionContext ac = invocation.getInvocationContext();
                            // 相当于request.getParameters(); 
                            final Map<String, Object> parameters = retrieveParameters(ac);
 
                            if (LOG.isDebugEnabled()) {
                                LOG.debug("Setting params " + getParameterLogMap(parameters));
                            }
 
                            if (parameters != null) {
                                Map<String, Object> contextMap = ac.getContextMap();
                                try {
                                    ReflectionContextState.setCreatingNullObjects(contextMap, true);
                                    ReflectionContextState.setDenyMethodExecution(contextMap, true);
                                    ReflectionContextState.setReportingConversionErrors(contextMap, true);
 
                                    ValueStack stack = ac.getValueStack();
                                    // 将参数赋值给Action中的JavaBean 
                                    setParameters(action, stack, parameters);
                                } finally {
                                    ReflectionContextState.setCreatingNullObjects(contextMap, false);
                                    ReflectionContextState.setDenyMethodExecution(contextMap, false);
                                    ReflectionContextState.setReportingConversionErrors(contextMap, false);
                                }
                            }
                        }
                        return invocation.invoke();
                    }

------------------------------------------------------------------------------------------------------------------

    2)模型驱动(在开发中应用比较多)
        使用ModelDriven接口,对请求数据进行封装。
        步骤:
            *   声明一个JavaBean对象并且必须实例化对象。
                >   private User user = new User();
            *   Action类实现ModelDriven接口
                >   public class Login3Action extends ActionSupport implements ModelDriven

            *   重写getModel()方法
                >   public Object getModel() { return this.user; }

        优点:解决了属性驱动存在的问题
            *   不需要将Action封装成JavaBean
            *   解决了在页面中使用ognl表达式的问题
        缺点:一次只能封装一个JavaBean对象,getModel()方法只能返回一个Bean。

        很多关于模型驱动的拦截器都是ModelDriven拦截器操作的:
            com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor

        示例代码:

            /*

             * 使用模型驱动获取请求参数
             */
            public class Login3Action extends ActionSupport implements ModelDriven {
                private User user = new User();
 
                public Object getModel() {
                    return this.user;
                }
 
                public String login() throws Exception {
                    HttpServletRequest request = ServletActionContext.getRequest();
                    System.out.println(user.getUsername() + ": " + user.getPassword());
                    if ("tom".equals(user.getUsername()) && "123".equals(user.getPassword())) {
 
                        request.getSession().setAttribute("username", user.getUsername());
 
                        return "success.jsp";
                    } else {
                        request.setAttribute("msg", "用户名或密码错误");
                        return "login.jsp";
                    }
                }
            }

        实现原理:
            1、在Action中声明一个初始化的JavaBean对象。
            2、实现ModelDriven接口
            3、重写getModel()方法
            4、在拦截器中实现如下代码:

                /*
                 * 模型驱动
                 */
                // 得到HelloAction类中声明的User对象
                Object actionObject = c.newInstance();
 
                // 判断HelloAction是否实现了MyModelDriven接口
                if(actionObject instanceof MyModelDriven){
                    // 将子类强转成父类
                    MyModelDriven model = (MyModelDriven)actionObject;
 
                    // 获取HelloAction内部的User对象,然后把请求参数封装到User对象中
                    BeanUtils.populate(model.getModel(), request.getParameterMap());
                } else {
                    // 1、属性驱动
                    actionObject = c.newInstance();
                    // 将请求参数封装到Action中(底层也是反射实现的)
                    BeanUtils.populate(actionObject, request.getParameterMap());
                }

——将请求参数封装到集合(了解)

原理:使用ognl表达式实现。

1、将数据封装到List集合
    页面:
        用户名1:<input type="text" name="users[0].username" /><br/>

        密    码1:<input type="password" name="users[0].password" /><br/>
 
        用户名2:<input type="text" name="users[1].username" /><br/>
        密    码2:<input type="password" name="users[1].password" /><br/>

Action类:
        private List<User> users;
        get / set方法

2、将数据封装到Map集合
    页面:
        用户名1:<input type="text" name="users['aaa'].username" /><br/>

        密    码1:<input type="password" name="users['aaa'].password" /><br/>
 
        用户名2:<input type="text" name="users['bbb'].username" /><br/>
        密    码2:<input type="password" name="users['bbb'].password" /><br/>

    Action类:
        private Map<String, User> users;
        get / set方法


——总结

1、Action接收请求参数

*   关于Struts2中的MVC
    *   属性驱动
        >   直接将Action作为JavaBean。
        >   Action中封装JavaBean,在页面上需要使用ognl表达式来给组件起名。
    *   模型驱动
        >   让Action实现ModelDriven接口,重写getModel()方法实例化一个JavaBean对象,该方法返回的就是实例化的JavaBean对象。
    *   关于请求参数封装到集合
        >   List
        >   Map

Struts2之处理请求参数的更多相关文章

  1. struts2 action接收请求参数和类型转换

    1,action接收请求参数 在struts2中action是什么?(struts2是一个mvc框架)         V:jsp        M:action         C:action  ...

  2. struts2框架之请求参数(参考第二天学习笔记)

    获取请求参数 请求参数:表单中的数据,或者是超链接中的数据. 1. 得到request,再通过request来获取.2. 属性驱动 在Action中提供与表单字段名称相同的属性即可. 而一个名为par ...

  3. struts2-Action处理请求参数

    struts2 和 MVC 定义关系 StrutsPrepareAndExecuteFilter : 控制器 JSP : 视图 Action : 可以作为模型,也可以是控制器 struts2 Acti ...

  4. Struts2请求参数校验

    校验的分类 客户端数据校验 和 服务器端数据校验 客户端数据校验 ,通过JavaScript 完成校验 (改善用户体验,使用户减少出错 ) 服务器数据校验 ,通过Java代码 完成校验 struts2 ...

  5. 请求参数到表述层的类型转换——Struts2

    一.简介 说明:HTTP 协议传输数据没有类型的概念,在服务器端是通过 request.getParameter().request.getParameterValue() 方法得到请求参数为 Str ...

  6. struts2视频学习笔记 11-12(动态方法调用,接收请求参数)

    课时11 动态方法调用 如果Action中存在多个方法时,可以使用!+方法名调用指定方法.(不推荐使用) public String execute(){ setMsg("execute&q ...

  7. 十一、Struts2封装请求参数的方式

    十一.Struts2封装请求参数的方式 方式一.Action 本身作为model对象,通过成员setter封装(一个名字为params的拦截器干的) 注意:表单中的名称要和动作类中的名称一致(这是必须 ...

  8. struts2之请求参数接收

    struts2之请求参数接收 1. 采用基本类型接受请求参数(get/post)在Action类中定义与请求参数同名的属性,struts2便能自动接收请求参数并赋予给同名的属性.请求路径:http:/ ...

  9. struts2获取请求参数的三种方式及传递给JSP参数的方式

    接上一篇文章 package test; import com.opensymphony.xwork2.ActionSupport; import javax.servlet.http.*; impo ...

随机推荐

  1. ThinkPHP3.2.3使用PHPExcel类操作excel导入读取excel

    方法一: 1. 下载PHPExcel并保存在如下位置: 2. 在控制器中引用 vendor("PHPExcel.PHPExcel"); $objReader = \PHPExcel ...

  2. P2491 消防/P1099 树网的核

    P2491 消防/P1099 树网的核 双倍经验,双倍快乐. 题意 在一个树上选择一段总长度不超过\(s\)的链使所有点到该链距离的最大值最小. 输出这个最小的值. 做法 Define:以下\(s\) ...

  3. odoo源码学习之任务中的阶段字段stage_id

    # 案例0004针对form表单 class Task(models.Model): _name = "project.task" _description = "对于项 ...

  4. ts 学习笔记 - 进阶篇 1

    目录 进阶 类型别名 字符串字面量类型 元祖 例子 越界的元素 枚举 手动赋值 常数项和计算所得项 常数枚举 外部枚举 进阶 类型别名 类型别名用来给一个类型起个新名字 type Name = str ...

  5. Intouch/ifix关于语音报警的一种设置思路

    工控项目最近升级改造,需要使用Intouch/ifix提供一个语音报警功能.这个不像先前提供的单一的声音报警,业主方要求能详细的提供某某水泵或者是某某设备故障报警,这就要求我们这边对语音解析或者基础控 ...

  6. 【干货】WordPress系统级更新,程序升级

    [干货]WordPress系统级更新,程序升级 网站技术日新月异,更新升级是维护工作之一,长时间不升级的程序,就如长时间不维护的建筑物一样,会加速老化.功能逐渐缺失直至无法使用.在使用WordPres ...

  7. Calcite(一):javacc语法框架及使用

    是一个动态数据管理框架. 它包含许多组成典型数据库管理系统的部分,但省略了存储原语.它提供了行业标准的SQL解析器和验证器,具有可插入规则和成本函数的可自定义优化器,逻辑和物理代数运算符,从SQL到代 ...

  8. 并发编程——Java线程的6种状态及切换

    前言 本次主要分享一下Java线程的六种状态及其转换. 如果对于线程的创建方式不太了解,推荐观看并发编程--认识java里的线程 线程的状态及其转换 操作系统线程的五种状态 新建(NEW) 就绪(RU ...

  9. Linux下MySQL基础及操作语法

    什么是MySQL? MySQL是一种开源关系数据库管理系统(RDBMS),它使用最常用的数据库管理语言-结构化查询语言(SQL)进行数据库管理.MySQL是开源的,因此任何人都可以根据通用公共许可证下 ...

  10. 抄书抄博客毒害社区的Writer几时休?

    曾几何时,博客园用户也渐渐分成了两类人:Writer和Coder. 何为Coder?就是认认真真写代码,平时分享工作中的一些问题.好的解决方案,或者写一些实用的原理技术文.答疑解惑的教程技术文. 何为 ...