• 动态Result配置


    步骤一:建立DynaAction,主要代码如下:
    package com.asm;

    public class DynaAction extends ActionSupport {

        private String username;

        private String nextAction;

     

        public String execute() throws Exception {

           if (username.equals("admin")) {

               nextAction = "admin";

           } else if (username.equals("user")) {

               nextAction = "user";

           } else {

               nextAction = ERROR;

           }

           return SUCCESS;

        }

        ...省略get/set方法

    }

    步骤二、建立jsp页面dyna.jsp,主要是为了向DynaAction中传递username参数。

    步骤三、相关配置如下:

    <package name="dynaTest" extends="pubResult">

           <action name="dyna" class="com.asm.DynaAction">

               <result name="success"type="chain">${nextAction}</result>

           </action>

     

           <action name="admin" >

               <result>/admin.jsp</result>

           </action>

     

           <action name="user">

               <result>/user.jsp</result>

           </action>

    </package>

    分析:当dyna.jsp把参数传递到DynaAction中去时,如果传递的值为admin,我们便设定了nextAction的值admin,在配置文件中我们通过${nextAction}(用在struts配置文件中的ognl,其实nextAction的值是存在值栈中,我们通过${}这样的形式取出。在此只作了解)来获取值便为admin,随后再继续把请求传递到下一个Action中去(此时也即admin.action),为了方便我们设定了两个ForwardAction:admin.action和user.action。这样便可以跳到指定的jsp页面。 原理:dyna.action执行后会继续把请求传递给下一个Action,而下一个Action的到底是哪一个Action,是通过DynaAction中动态指定的,比如这里是根据传递的username的值指定。

  • 相关阅读:
    AngularJs $location 和 $window
    AngularJS——自定义服务详解(factory、service、provider)
    angularAMD+requireJs
    angular ui-router时要使用html5Mode=true
    CSS3的calc()使用
    React Ajax this.IsMounted() is not a function
    css有用的代码片段
    8908
    454
    234
  • 原文地址:https://www.cnblogs.com/mrcharles/p/11879881.html
Copyright © 2020-2023  润新知