• Struts2之Result详解


      上一篇我们把Struts2中的Action接收参数的内容为大家介绍了,本篇我们就一起来简单学习一下Action的4种Result type类型,分为:dispatcher(服务端页面跳转);redirect(客户端页面跳转);chain(动作链跳转);redirectAction(客户端Action跳转),当然还有其他类型,这里我们就以这四种为例为大家介绍一下,其他几种大家有兴趣单独学习。下面我们一起来看一下上面四种的具体实现,首先是我们的配置文件:

    <package name="resultFilter" namespace="/resultFilter" extends="struts-default">
            <!-- http://localhost:8080/Struts/resultFilter/default -->
            <action name="default" class="com.edu.action.ResultFilter">
                <result name="success">/default.jsp</result>
            </action>
            
            <!-- http://localhost:8080/Struts/resultFilter/dispatcher 服务端跳转-->
            <action name="dispatcher" class="com.edu.action.ResultFilter" method="Dispatcher">
                <result name="success" type="dispatcher">/dispatcher.jsp</result>
            </action>
            
            <!-- http://localhost:8080/Struts/resultFilter/redirect   客户端跳转 -->
            <action name="redirect" class="com.edu.action.ResultFilter" method="Redirect">
                <result name="success" type="redirect">/redirect.jsp</result>
            </action>
            
            <!-- http://localhost:8080/Struts/resultFilter/chain 动作链跳转-->
            <!-- http://blog.csdn.net/randomnet/article/details/8656759 -->
            <action name="chain" class="com.edu.action.ResultFilter" method="Chain">
                <result name="success" type="chain">chain1</result>
            </action>
            <action name="chain1" class="com.edu.action.ResultFilter" method="Chain">
                <result name="success">/chain.jsp</result>
            </action>
            
            <!-- http://localhost:8080/Struts/resultFilter/redirectAction 客户端跳转-->
            <action name="redirectAction" class="com.edu.action.ResultFilter" method="RedirectAction">
                <result name="success" type="redirectAction">
                    <param name="namespace">/redirectAction</param>
                    <param name="actionName">default</param>
                </result>
            </action>
    
            <!-- http://localhost:8080/Struts/resultFilter/redirectAction 客户端跳转(单值传参)-->
            <action name="redirectAction" class="com.edu.action.ResultFilter" method="RedirectAction">
                <result name="success" type="redirectAction">
                    <param name="namespace">/redirectAction</param>
                    <param name="actionName">default?value1=${value1}</param>
                </result>
            </action>
    
            <!-- http://localhost:8080/Struts/resultFilter/redirectAction 客户端跳转(多值传参)-->
            <action name="redirectAction" class="com.edu.action.ResultFilter" method="RedirectAction">
                <result name="success" type="redirectAction">
                    <param name="namespace">/redirectAction</param>
                    <param name="actionName">default</param>
                    <param name="value1">${value1}</param>
                    <param name="value2">${value2}</param>
                </result>
            </action>
        </package>
        
        <package name="redirectAction" namespace="/redirectAction" extends="struts-default">
            <action name="default" class="com.edu.action.ResultFilter">
                <result name="success">/redirectAction.jsp</result>
            </action>
        </package>

      default action我们并没有设置result的type类型,系统默认设置为:dispatcher类型,dispatcher类型和redirect下只能跳转到页面,两者的区别在于,dispatcher类型属于服务端调转,地址栏不更新,redirect属于客户端跳转,地址栏会更新。chain类型属于动态链跳转,故我们在第二个Action中任然可以拿到传递给第一个Action的参数,我们可以在页面上添加<s:debug></s:debug>来查看具体信息。最后一个redirectAction大家一看配置一定已经明白了,这里就不再赘述。下面我们看一下chain动态链跳转,首先看一下我的jsp页面:

    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    
    <%@taglib uri="/struts-tags" prefix="s"%>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <base href="<%=basePath%>">
        
        <title>Result类型跳转</title>
        
        <meta http-equiv="pragma" content="no-cache">
        <meta http-equiv="cache-control" content="no-cache">
        <meta http-equiv="expires" content="0">    
        <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
        <meta http-equiv="description" content="This is my page">
        <!--
        <link rel="stylesheet" type="text/css" href="styles.css">
        -->
    
      </head>
      
      <body>
          result的chain跳转类型
          <s:debug></s:debug>
      </body>
    </html>

      运行我们的工程,打开debug:

      

      这样大家是不是对于动态链跳转认识更加清楚一些,更具体的内容,请参考:http://blog.csdn.net/randomnet/article/details/8656759


       下面我们来一起学习一下global-reslut全局结果集的配置,首先先看配置文件:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
        "http://struts.apache.org/dtds/struts-2.3.dtd">
    
    <struts>
        
        <package name="default" namespace="/" extends="struts-default">
            <!-- http://localhost:8080/Struts13/login?name=3 -->
            <global-results>
                <result name="other">/other.jsp</result>
            </global-results>
        
            <action name="login" class="com.edu.action.Login">
                <!-- http://localhost:8080/Struts13/login?name=1 -->
                <result name="success">/success.jsp</result>
                <!-- http://localhost:8080/Struts13/login?name=2 -->
                <result name="error">/error.jsp</result>
            </action>
        </package>
    
    </struts>

       下面我们再来看一下Action中的返回参数:

    public class Login extends ActionSupport implements ModelDriven<User>{
        private User user = new User();
        
        @Override
        public String execute() throws Exception {
            if(user.getName() == 1){
                return SUCCESS;
            } else if(user.getName() == 2){
                return ERROR;
            } else {
                return "other";
            }
        }
    
        public User getModel() {
            return user;
        }
    }

      我们看到当我们的传入的Name值等于1和2时,Action会返回other,我们再移步配置文件,我们发现,login Action下的Result结果处理类型并不包括other类型,那是哪里这样的话是不是就会没有访问结果返回呢?答案一定是不,我们仔细观察我们的配置文件,我们发现我们在上面配置了

    <global-results>
        <result name="other">/other.jsp</result>
    </global-results>

      global-results就是我们的全局结果集设置,这样当我们的other返回给Action后,就会被这个result处理。


       有了全局结果集,下面我们来一起研究下动态结果集的概念,首先我们看一下我们的Action内容:

    public class resultJsp extends ActionSupport implements ModelDriven<User>{
        private User user = new User();
        private String resultJsp;
    
        public String getResultJsp() {
            return resultJsp;
        }
    
        public void setResultJsp(String resultJsp) {
            this.resultJsp = resultJsp;
        }
    
        @Override
        public String execute() throws Exception {
            if(user.getName() == 1){
                resultJsp = "success.jsp";
            } else {
                resultJsp = "error.jsp";
            }
            return SUCCESS;
        }
    
        public User getModel() {
            return user;
        }
    }

      我们看到当我们的name值等于1时,resultJsp我们设置的参数是success.jsp,我们的成功操作结果页面,那么我们的配置文件时如何识别并进行处理的呢?我们来一起看一下配置文件的设置:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
        "http://struts.apache.org/dtds/struts-2.3.dtd">
    
    <struts>
        
        <package name="default" namespace="/" extends="struts-default">
        
            <default-action-ref name="index"></default-action-ref>
            
            <!-- http://localhost:8080/Struts/login?name=1 -->
            <action name="login" class="com.edu.action.resultJsp">
                
                <result>${resultJsp}</result>
                
            </action>
        </package>
    
    </struts>

      我们看到result之间我们使用${resultJsp}来动态设置跳转的页面,我们知道result在没有设置Type类型时为dispatcher,服务端页面跳转,我们的浏览器地址栏不显示跳转页面名称。


       接下来我们再来看一下动态参数传递的内容,就是当我们的Action处理完成后,在跳转到新页面时,将一些参数动态传递出去。我们先来看一下我们的Action中的处理:

    public class resultJsp extends ActionSupport{
        private String name;
        
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        @Override
        public String execute() throws Exception {
            return SUCCESS;
        }
    }

      我们设置了一个全局变量name,接下来我们就通过配置文件将name值动态的传递到下一页,配置文件:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
        "http://struts.apache.org/dtds/struts-2.3.dtd">
    
    <struts>
        
        <package name="default" namespace="/" extends="struts-default">
        
            <default-action-ref name="index"></default-action-ref>
            
            <!-- http://localhost:8080/Struts/login?name=1 -->
            <action name="login" class="com.edu.action.resultJsp">
                
                <!-- 这里使用 type = redirect 是为了  -->
                <result name="success" type="redirect">/success.jsp?n=${name}</result>
                
            </action>
        </package>
    
    </struts>

      这样我们的参数便可以传递到下一个页面请求中了,这里需要提示一下就是,result的类型,这里是为了让大家在地址栏能清楚的看到参数传递的过程,我们知道redirect是客户端跳转,所以我们在地址栏是可以看到跳转路径的。


       最后在插一句,在介绍全局结果集,我们提到,当我们的action下面没有设置返回名称的result时,struts2回去全局结果集进行查找,如果都没有找到处理结果会出现什么情况呢?具体的实验就不再带领大家一起实现了,这里我只把我这测试的结果展示一下,大家做个参考,了解一下:

      

      到这里关于Struts2的result部分就为大家介绍完了,接下来我们将一起学习ONGL表达式,后续内容持续更新中。。。

  • 相关阅读:
    JavaScript开发工具WebStorm v2022.2简体中文激活码
    分析J2SE和J2EE的Java剖析程序JProfiler
    Python判断Linux用户是否存在
    php连接MySQL数据库
    centos7镜像部署的phpfpm的9000端口无法被外部访问
    zabbix执行Python脚本报错error: import: command not found
    编译失败configure: error: Cannot find ldap libraries in /usr/lib
    PHP编译安装报错cannot stat `ext/phar/phar.phar': No such file or directory
    count(1)和count(*)的区别
    PHP编辑报错/lib64/liblber2.4.so.2: could not read symbols: Invalid operation
  • 原文地址:https://www.cnblogs.com/AndroidJotting/p/6528075.html
Copyright © 2020-2023  润新知