【Struts2笔记整理七】值栈

2024-02-14 12:58
文章标签 整理 笔记 struts2 值栈

本文主要是介绍【Struts2笔记整理七】值栈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

版权声明:本文为 小异常 原创文章,非商用自由转载-保持署名-注明出处,谢谢!
本文网址:https://blog.csdn.net/sun8112133/article/details/106677519

文章目录

  • 一、值栈的内部结构
  • 二、值栈与 ActionContext 的关系
  • 三、操作值栈
    • 1、获得值栈
    • 2、向值栈中存入数据
      • 1)在 Action 中提供属性的 get 方法
      • 2)使用 ValueStack 中本身的方法(推荐)
    • 3、获取值栈数据
    • 4、EL 为何能访问到值栈的数据






值栈(ValueStack)Struts2 中也是非常重要的知识,它其实类似于一个数据中转站,Struts2 框架中的所有数据都保存到了 ValueStack 中。ValueStack 贯穿整个 Action 的生命周期,只要 Action 一创建,Struts2 就会创建一个 ValueStack 对象。

ValueStack 的实现类是 OgnlValueStack 对象,这个对象实现了 ValueStack 接口。

大家需要记住在 ValueStack 中存入的数据在任何地方都能把它取出来。


一、值栈的内部结构

ValueStack 的内部主要有两个区域:root 区域context 区域

07值栈内部结构

  • root 区域: 其实就是一个 ArrayList。里面一般放置对象。获取 root 的数据不需要加 #
  • context 区域: 其实就是一个 Map。里面放置是 web 开发常用的对象数据引用。获取 context 数据需要加 #

我们一般所说的操作 ValueStack,通常指的是操作 ValueStack 中的 root 区域



二、值栈与 ActionContext 的关系

说起 ActionContext,大家肯定会想到 Servlet 中的 ServletContext

ServletContext 是 Servlet 的上下文。所谓的上下文其实就是它包含了全部,和上知五百年下知五百年道理一样,包含了全部信息;

ActionContext 是 Action 的上下文。通过源码得知:当请求过来的时候,执行过滤器中的 doFilter 方法,在这个方法中创建 ActionContext 对象,在创建 ActionContext 的过程中,就会创建 ValueStack 对象,并将 ValueStack 对象传递给 ActionContext 对象。所以我们 可以通过 ActionContext 获取 ValueStack 对象 了。

ActionContext 对象之所以能够访问 Servlet 的 API (访问的是域对象的数据)。因为在其内部有值栈的引用。



三、操作值栈

1、获得值栈

获得 值栈 有两种方式:

  1. 通过 ActionContext 对象获取 值栈
  2. 通过 Request 对象获取 值栈。在 Struts2 的内部,已经将 值栈 存入到了 Request 中。
@Override
public String execute() throws Exception {// 一种:通过 ActionContext 对象获得ValueStack valueStack1 = ActionContext.getContext().getValueStack();// 二种:通过 request 对象获得  "struts.valueStack"ValueStack valueStack2 = (ValueStack) ServletActionContext.getRequest().getAttribute(ServletActionContext.STRUTS_VALUESTACK_KEY);// 一个 Action 的实例,只会创建一个 ValueStack 的对象 System.out.println(valueStack1 == valueStack2);   // truereturn NONE;
}

2、向值栈中存入数据

值栈 中存入数据有两种方式:

  1. Action 中提供属性的 get 方法;
  2. 使用 ValueStack 中本身的方法(推荐)。

1)在 Action 中提供属性的 get 方法

默认情况下,将 Action 对象放入到值栈中,而 Action 中的属性也会存入,但是我们不推荐使用这种方式,因为它存入的数据不在栈顶。

  • 编写 JSP

    <body><h1>查看值栈的内部结构</h1><s:debug></s:debug><!-- 利用 Action 在值栈中的特性 --><s:property value="user.username" /><s:property value="user.password" />
    </body>
    
  • 编写 Action

    /*** 操作 ValueStack* 方式一:利用 Action 本身在值栈中的特性。*/
    public class ValueStackDemo3 extends ActionSupport {private User user;public User getUser() {return user;}@Overridepublic String execute() throws Exception {// 向 ValueStack 中存值user = new User("张三", "222");return SUCCESS;}
    }
    

2)使用 ValueStack 中本身的方法(推荐)

  • 编写 JSP

    <body><h1>查看值栈的内部结构</h1><s:debug></s:debug><!-- 调用 ValueStack 本身的方法,如果有两个相同名字的,优先栈顶的 --><s:property value="username" /><s:property value="password" />
    </body>
    
  • 编写 Action

    /*** 操作 ValueStack* 方式二:调用值栈中的方法实现*/
    public class ValueStackDemo4 extends ActionSupport {@Overridepublic String execute() throws Exception {// 向值栈中保存数据// 获得值栈对象ValueStack valueStack = ActionContext.getContext().getValueStack();// 使用 push(Object obj);   set(String key, Object obj);// 一般保存对象用 push,保存集合用 setUser user = new User("李四", "333");// 现在 user 在栈顶的位置valueStack.push(user);valueStack.set("name", "王五");    // 创建一个 Map 集合,将 Map 压入到栈中return SUCCESS;}
    }
    

3、获取值栈数据

获取值栈中的数据就是在页面中使用 OGNL 表达式即可。

  • 获取 root 的数据时不需要加 # 号;
  • 获取 context 数据需要加 # 号。
<body><h3>获取 root 的数据</h3><s:property value="username" /><h3>获取 context 的数据</h3><s:property value="#name" />
</body>

4、EL 为何能访问到值栈的数据

因为 Struts2 框架的底层对 request.getAttribute(String name); 进行了增强,首先从 request 中获取值,如果找到了就返回,如果没找到就从值栈中获取。



博客中若有不恰当的地方,请您一定要告诉我。前路崎岖,望我们可以互相帮助,并肩前行!



这篇关于【Struts2笔记整理七】值栈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/708558

相关文章

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

忽略某些文件 —— Git 学习笔记 05

忽略某些文件 忽略某些文件 通过.gitignore文件其他规则源如何选择规则源参考资料 对于某些文件,我们不希望把它们纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常它们都是些自动生成的文件,比如日志文件、编译过程中创建的临时文件等。 通过.gitignore文件 假设我们要忽略 lib.a 文件,那我们可以在 lib.a 所在目录下创建一个名为 .gi

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个