• struts结果页面配置及对表单操作


    结果页面配置

      全局结果页面

        1 result标签配置action方法的返回值到不同的路径里面

        2 创建两个action,执行默认的方法execute方法,让两个action的方法都返回success,返回success之后,配置到同一个页面里面

        (1)如果多个action,方法里面返回值相同的,到页面也是相同的,这个时候可以使用全局结果页面配置

        <package name="demo2" extends="struts-default" namespace="/">
        
            <action name="book" class="com.wm.action.BookAction">
                <result name="success">/hello.jsp</result>
            </action>
            
            <action name="orders" class="com.wm.action.OrdersAction">
                <result name="success">/hello.jsp</result>
            </action>
            
        </package>

        (2)在package标签里面配置

        <package name="demo2" extends="struts-default" namespace="/">
        
            <global-results>
                <result name="success">/hello.jsp</result>
            </global-results>
        
            <action name="book" class="com.wm.action.BookAction">
                <!-- <result name="success">/hello.jsp</result> -->
            </action>
            
            <action name="orders" class="com.wm.action.OrdersAction">
                <!-- <result name="success">/hello.jsp</result> -->
            </action>
            
        </package>

    Result标签的type属性

      1 result标签里面除了name属性之外,还有一个属性 type属性

        (1)type属性:如何到路径里面(转发还是重定向)

      2 type属性值

        (1)默认值,做转发操作,值是 dispatcher

                 做重定向操作,值是 redirect

        (2)上面两个值dispatcher、redirect,这两个值一般针对到页面中配置,

        配置到其他的action里面

        - chain:转发到action,一般不用,缓存问题

        - redirectAction:重定向到action

    Action获取表单提交数据

      1 web阶段,提交表单到servlet里面,在servlet里面使用request对象里面的方法获取,getParameter,getParameterMap

      2 提交表单到action,但是action没有request对象,不能直接使用request对象

      3 action获取表单提交数据主要三种方式

        (1)使用ActionContext类

        (2)使用ServletActionContext类

        (3)使用接口注入方式

      使用ActionContext类获取

            //第一种方式 使用ActionContext类获取
            //1 获取ActionContext对象
            ActionContext context = ActionContext.getContext();
            //2 调用方法得到表单数据
            // key是表单输入项name属性值,value是输入的值
            Map<String, Object> map = context.getParameters();
            
            Set<String> keys = map.keySet();
            for (String key : keys) {
                //根据key得到value
                //数组形式:因为输入项里面可能有复选框情况
                Object[] obj = (Object[]) map.get(key);
                System.out.println(Arrays.toString(obj));
            }

      使用ServletActionContext类获取

        (1)调用类里面静态方法,得到request对象

            //第2种方式 使用ServletActionContext类获取
            //1 使用ServletActionContext获取request对象
            HttpServletRequest request = ServletActionContext.getRequest();
            //2 调用request里面的方法得到结果
            String username = request.getParameter("username");
            String password = request.getParameter("password");
            String address = request.getParameter("address");
            
            System.out.println(username+":"+password+":"+address);

      使用接口注入(了解)

        1 让action实现接口,为了得到request对象

    public class Form3DemoAction extends ActionSupport implements ServletRequestAware {
    
        private HttpServletRequest request ;
        @Override
        public void setServletRequest(HttpServletRequest request) {
            this.request = request;
        }
        
        public String execute() throws Exception {
            request.getParameter("");
            
            return NONE;
        }
    }

    在action操作域对象

      1 request、session、servletContext域对象

      2 使用ServletActionContext类操作

            //操作三个域对象
            //1 request域
            HttpServletRequest request = ServletActionContext.getRequest();
            request.setAttribute("req", "reqValue");
            
            //2 session域
            HttpSession session = request.getSession();
            session.setAttribute("sess", "sessValue");
            
            //3 ServletContext域
            ServletContext context = ServletActionContext.getServletContext();
            context.setAttribute("contextname", "contextValue");

    Struts2封装获取表单数据方式

      原始方式获取表单封装到实体类对象

            //1 获取表单数据
            HttpServletRequest request = ServletActionContext.getRequest();
            String username = request.getParameter("username");
            String password = request.getParameter("password");
            String address = request.getParameter("address");
            
            //2 封装到实体类对象里面
            User user = new User();
            user.setUsername(username);
            user.setPassword(password);
            user.setAddress(address);

      属性封装(会用)

        1 直接把表单提交属性封装到action的属性里面

        2 实现步骤

        (1)在action成员变量位置定义变量

        - 变量名称和表单输入项的name属性值一样

        (2)生成变量的set方法(把set和get方法都写出来)

        //1 定义变量
        //变量的名称和表单输入项name属性值一样
        private String username;
        private String password;
        private String address;
        
        //2 生成变量的set和get方法
        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;
        }
    
        public String getAddress() {
            return address;
        }
    
        public void setAddress(String address) {
            this.address = address;
        }
    View Code

         3 使用属性封装获取表单数据到属性里面,不能把数据直接封装到实体类对象里面

      模型驱动封装(重点)

        1 使用模型驱动方式,可以直接把表单数据封装到实体类对象里面

        2 实现步骤

        (1)action实现接口 ModelDriven

        (2)实现接口里面的方法 getModel方法

        - 把创建对象返回

        (3)在action里面创建实体类对象

    public class DataDemo2Action extends ActionSupport implements ModelDriven<User>{
    
        //创建对象
        //前提要求: 表单输入项name属性值 和 实体类属性名称一样
        private User user = new User();
        public User getModel() {
            //返回创建user对象
            return user;
        }
    
        @Override
        public String execute() throws Exception {
            
            System.out.println(user);
            return NONE;
        }
    }

        3 使用模型驱动和属性封装注意问题:

          在一个action中,获取表单数据可以属性封装,使用模型驱动封装,

          不能同时使用属性封装和模型驱动封装获取同一个表单数据

          如果同时使用,只会执行模型驱动

     

      表达式封装(会用)

        1 实现过程

        (1)使用表达式封装可以把表单数据封装到实体类对象里面

           第一步 在action里面声明实体类

          第二步 生成实体类变量的set和get方法

    public class DataDemo3Action extends ActionSupport {
    
        //1 声明实体类
        private User user;
        private Book book;
        
        //2 生成实体类变量的set和get方法
        public Book getBook() {
            return book;
        }
        public void setBook(Book book) {
            this.book = book;
        }
        public User getUser() {
            return user;
        }
        public void setUser(User user) {
            this.user = user;
        }
    
        @Override
        public String execute() throws Exception {
            System.out.println(user);
            System.out.println(book.getBname());
            return NONE;
        }
    }

          第三步 在表单输入项的name属性值里面写表达式形式,把表达式封装归类到属性封装里面

        <form action="${pageContext.request.contextPath }/data3.action" method="post">
            username:<input type="text" name="user.username"/>
            <br/>
            password:<input type="text" name="user.password"/>
            <br/>
            address:<input type="text" name="user.address"/>
            <br/>
            bname: <input type="text" name="book.bname"/>
            <br/>
            <input type="submit" value="提交"/>
        </form>

      比较表达式封装和模型驱动封装

        1 使用表达式封装和模型驱动封装都可以把数据封装到实体类对象里面

        2 不同点:

        (1)使用模型驱动只能把数据封装到一个实体类对象里面

        - 在一个action里面不能使用模型驱动把数据封装到不同的实体类对象里面

        (2)使用表达式封装可以把数据封装到不同的实体类对象里面

          

          

    封装到集合里面

      封装数据到List集合

        第一步 在action声明List

        第二步 生成list变量的set和get方法

    public class ListAction extends ActionSupport {
    
        // 1 声明List变量
        private List<User> list;
        // 2 生成get和set方法
        public List<User> getList() {
            return list;
        }
        public void setList(List<User> list) {
            this.list = list;
        }
    
        @Override
        public String execute() throws Exception {
            System.out.println(list);
            return NONE;
        }
    }

        第三步 在表单输入项里面写表达式

    <form action="${pageContext.request.contextPath }/list.action" method="post">
            <!-- list[0] : 表示list集合中第一个user对象 -->
            username:<input type="text" name="list[0].username"/>
            <br/>
            password:<input type="text" name="list[0].password"/>
            <br/>
            address:<input type="text" name="list[0].address"/>
            
            <br/><br/>
            
            username:<input type="text" name="list[1].username"/>
            <br/>
            password:<input type="text" name="list[1].password"/>
            <br/>
            address:<input type="text" name="list[1].address"/>
            <br/>
            <input type="submit" value="提交"/>
        </form>

      封装数据到Map集合

        第一步 声明map集合

        第二步 生成get和set方法

    public class MapAction extends ActionSupport {
    
        // 1 声明map集合
        private Map<String,User> map;
           //第二步 生成get和set方法
        public Map<String, User> getMap() {
            return map;
        }
        public void setMap(Map<String, User> map) {
            this.map = map;
        }
        
        @Override
        public String execute() throws Exception {
            System.out.println(map);
            return NONE;
        }
    }

        第三步 在表单输入项的name属性值里面写表达式

        <form action="${pageContext.request.contextPath }/map.action" method="post">
            <!-- 设置key值 map['key值']
                设置value值
             -->
            username:<input type="text" name="map['one'].username"/>
            <br/>
            password:<input type="text" name="map['one'].password"/>
            <br/>
            address:<input type="text" name="map['one'].address"/>
            
            <br/><br/>
            
            username:<input type="text" name="map['abcd'].username"/>
            <br/>
            password:<input type="text" name="map['abcd'].password"/>
            <br/>
            address:<input type="text" name="map['abcd'].address"/>
            <br/>
            <input type="submit" value="提交"/>
        </form>
  • 相关阅读:
    nodejs关于前后端图片上传的思路及实现代码
    vue项目better-scroll使用注意点
    nuxt.js的使用和开发,一款vue基于服务器SSR渲染工具
    vue-cli3.0中自定css、js和图片的打包路径
    Vue.js watch监视属性
    React Developers的10个超实用神奇工具
    Vue 3.0 体验 Vue Function API
    Dojo Store 概念详解
    React Native 实现城市选择组件
    java 环境变量 设置 问题
  • 原文地址:https://www.cnblogs.com/kpsmile/p/10093824.html
Copyright © 2020-2023  润新知