zoukankan      html  css  js  c++  java
  • Struts2学习(2)

    1.结果嗯配置

    (1)全局结果页面

    (2)局部结果页面

    (3)result标签type属性

    2.在action获取表单提交数据

    (1)使用ActionContext类获取

    (2)使用ServletActionContext类获取

    (3)使用接口注入方式获取

    3.struts2提供获取表单数据方式

    (1)属性封装

    (2)模型驱动封装

    4.struts2获取数据封装到集合中

    (1)封装到list集合

    (2)封装到map集合

    5.扩展,表达式封装和模型驱动比较

    结果页面配置

    全局结果页面

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

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

    <package name="demo1" extends="struts-default" namespace="/">
            <!-- 全局结果页面的配置 -->
            <global-results>
                <result name="success">/hello.jsp</result>
            </global-results>
    
            <action name="book" class="cn.itcast.action.BookAction">
                <!-- <result name="success">/hello.jsp</result> -->
            </action>
    
            <action name="orders" class="cn.itcast.action.OrderAction">
                <!-- <result name="success">/hello.jsp</result> -->
            </action>
    </package>

    Result标签的type属性

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

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

    2.type属性值

    (1)默认值,做转发操作,值是dispatcher(地址栏不会发生改变)

    <result name="success" type="dispatcher">/world.jsp</result>
            

    (2)做重定向操作,值是redirect。

    ctrl+f5是无缓存刷新。

    <action name="book" class="cn.itcast.action.BookAction">
                <result name="success" type="dispatcher">/world.jsp</result>
            </action>
    
            <action name="orders" class="cn.itcast.action.OrdersAction">
                <result name="success" type="redirect">/hello.jsp</result>
            </action>

    转发操作地址栏不会发生改变,而重定向地址栏会发生改变。

    输入book.action,内容改变了,但是地址栏没有发生改变。

    输入orders.action,地址栏发生改变。

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

    配置到其他的action里面。

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

    -redirectAction:重定向到action。

    加入了redirectAction后,页面就跳转到其他action中去了。

    <action name="book" class="cn.itcast.action.BookAction">
                <!-- action访问名称 -->
                <result name="success" type="redirectAction">orders</result>
            </action>
    
            <action name="orders" class="cn.itcast.action.OrdersAction">
                <result name="success">/hello.jsp</result>
            </action>

    运行如下所示:

    使用chain,地址没有发生改变(一般不用)。

    <action name="book" class="cn.itcast.action.BookAction">
                <!-- action访问名称 -->
                <result name="success" type="chain">orders</result>
            </action>
    
            <action name="orders" class="cn.itcast.action.OrdersAction">
                <result name="success">/hello.jsp</result>
            </action>

    redirectAction和redirect,跳转到其他页面进行处理。

    使用场景:

    Action获取表单提交数据

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

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

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

    (1)使用ActionContext类

    (2)使用ServletActionContext类

    (3)使用接口注入方式

    使用ActionContext类获取

    (1)因为方法不是静态的方法,需要创建ActionContext类

    (2)这个ActionContext类对象不是new出来的,是通过类的静态方法获取实例的。

    1 具体演示

    (1)创建表单,提交表单到action里面

    (2)在action使用ActionContext获取数据

    public class Form1DemoAction extends ActionSupport {
    
        @Override
        public String execute() throws Exception{
            //第一种方式 使用ActionContext类获取
            //1.获取ActionContext对象
            ActionContext context = ActionContext.getContext();
            //2.调用方法得到表单数据
            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));
            }
            
            return NONE;
        }
    }

    在struts.xml中是这样写的

    <!-- 获取表单提交的数据 -->
        <package name="demo2" extends="struts-default" namespace="/">
        <action name="form1" class="cn.itcast.form.Form1DemoAction"></action>
        </package> 

    form1.jsp中这样写

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

    使用ServletActionContext类获取

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

    public class Form1DemoAction extends ActionSupport {
    
        @Override
        public String execute() throws Exception{
            //第一种方式 使用ActionContext类获取
            //1.获取ActionContext对象
            ActionContext context = ActionContext.getContext();
            //2.调用方法得到表单数据
            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));
            }
            
            return NONE;
        }
    }

    在form1.jsp页面中只需要做这样的修改就可以了。

     <form action="${pageContext.request.contextPath }/form2.action" method="post">

    没有乱码:在struts2中有一个常量,如果表单提交方式是post,那么提交数据就不会出现乱码问题。

    为了防止struts的乱码,可以在struts.xml中加入

    <constant name="struts.i18n.encoding" value="utf-8"/>

    使用接口注入技术

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

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

    实现列表功能

    在action操作域对象

    1 request、session、servletContext域对象

    2 使用ServletActionContext类操作

    3 ServletContext

    在execute()方法中使用三个域对象如下所示:

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

    struts2封装获取表单数据方式

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

    越原始的方式越强大,越原始的方式越有效,就是比较麻烦而已。

    所以这种这种原始方需要掌握,框架就是把这些原始的方法封装了。

    原始步骤:

    public class Form4DemoAction extends ActionSupport{
    
        public String execute() throws Exception{
            //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);
            
            System.out.println(user.toString());
            System.out.println("hello");
            return NONE;
        }
    
    }

    属性封装

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

    2 实现步骤

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

    -变量名称和表单输入项的name属性值一样(类中变量名要和表单中的数据变量名一致)。

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

    封装了方法,帮我们自动实现。

    public class DataDemo1Action extends ActionSupport {
    
        //1 定义表单
        //变量的名称要和表单输入项name属性值一样
        private String username;
        private String password;
        private String address;
        
        //2生成变量的get和set方法
        
        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;
        }
    
        public String execute() throws Exception{
            System.out.println(username + ": " + password + ": " + address);
            return NONE;
        }
    }

    这样就可以直接得到数据。

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

    模型驱动封装(重点)

    这种方式用的最多

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

    里面的底层代码实际上就是第一种方式即原始方式,只不过它帮我们封装好了,我们可以直接使用。

    2 实现步骤

    (1)action实现接口 ModelDriven

    public class DataDemo2Action extends ActionSupport implements ModelDriven<User> {
    
        @Override
        public User getModel() {
            // TODO Auto-generated method stub
            return null;
        }
    }

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

    (3)实现接口里面的方法 getMethod方法

    -把创建对象返回

    //创建对象
        private User user = new User();
        public User getModel() {
            //返回创建user对象
            return user;
        }

    运行

    结果

    这里成功地把数据封装到了user中。

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

    (1)在一个action中,获取表单数据可以属性封装,使用模型封装,不能同时使用属性封装和模型驱动封装同时获取数据。如果两个都用,它只会执行模型驱动。

    使用属性封装就无法获得属性值了。

     表达式封装(会用)

    有的书也叫属性封装

    1 实现过程

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

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

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

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

    页面中代码是:

    <body>
        <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/>
        <input type="submit" value="提交"/>
        </form>
      </body>

    action中代码是:

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

    代码可以运行成功。

    2 把表达式封装归类到属性封装里面

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

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

    2 不同点:

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

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

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

    使用表达式封装不同实体类对象示例如下所示:

     <body>
        <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>
      </body>

    action里写

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

    运行之后

    成功。

    封装到集合里面

    封装数据到List集合

    第一步 在action声明List

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

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

    <body>
        <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/>
        
        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>
      </body>

    action中

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

    在struts.xml中做修改就是了。

    运行成功后

     封装数据到Map集合

    第一步 声明map集合

    第二步 生成get和set犯法

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

    map.jsp

    <body>
        <form action="${pageContext.request.contextPath }/map.action" method="post">
        <!-- 设置key值 map['key值'] -->
        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['two'].username"/><br/>
        password:<input type="text" name="map['two'].password"/><br/>
        address:<input type="text" name="map['two'].address"/><br/>
        
        <input type="submit" value="提交"/>
        </form>
      </body>

    action里

    public class MapAction extends ActionSupport {
    
        // 1 声明List变量
        private Map<String,User> map;
        // 2 生成set和get方法
        public Map<String, User> getMap() {
            return map;
        }
    
        public void setMap(Map<String, User> map) {
            this.map = map;
        }
    
        public String execute() throws Exception {
            
            System.out.println(map);
            return NONE;
        }
    }

    运行过程如下所示:

     

    运行结果如下所示:

  • 相关阅读:
    彻底理解c++的隐式类型转换
    golang1.16新特性速览
    配置CLion管理Qt项目国际化支持
    一道有趣的golang排错题
    计算机视觉 / 二维空间中,如何判断点在不在某个封闭图形内?
    如何使用google搜索?
    shuffle实现 / 洗牌算法
    Linux 命令行界面下,好玩的东西
    LAB5 Shell、外存管理与操作
    LAB6 网络通信 、 网卡驱动
  • 原文地址:https://www.cnblogs.com/liaoxiaolao/p/9902541.html
Copyright © 2011-2022 走看看