网站首页 > 技术文章 正文
作用域是指从哪些地方获取数据的区域,或者是获取的数据的作用范围,JSP九大内置对象中,有四个内置对象是可以用来保存数据和获取数据的,分别是:request、session、page、application,这四个内置对象中的数据作用范围都不一样,按照作用范围的大小排列,依次是:page<request<session<application。下面就介绍这四个作用域的区别及使用。
1.1、pageScope
page作用域:pageScope中的数据只在当前JSP页面里面生效,当跳转到其他的JSP页面时候,数据就失效了,也就是说,当前JSP页面中的数据不能被其他JSP页面访问到。要保存数据到page作用域里面,需要通过调用pageContext对象中的setAttribute()方法。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>JSP四大作用域pageScope</title>
</head>
<body>
<h3>JSP四大作用域pageScope</h3>
<%
String username = "Tom-2024";
// 保存数据到page作用域
pageContext.setAttribute("username", username);
%>
${pageScope.getOrDefault("username", "Default_value")}
</body>
</html>
如果我们使用的是EL表达式来获取page作用域中的数据,此时可以直接使用pageScope变量来获取对应的数据,pageScope本质上就是一个Map对象,里面保存了当前JSP页面中的可用数据。如下所示:
运行结果如下:
1.2、requestScope
request作用域:request是HTTP请求对象,它可以调用setAttribute()方法保存数据,调用getAttribute()方法获取数据,request作用域中的数据,只在当前这一次HTTP请求过程中有效,当这次HTTP请求结束之后,对应的数据也就失效了。要想保存数据到request作用域里面,只需要调用HttpServletRequest请求对象的setAttribute()方法即可。
如果我们使用的是EL表达式来获取request作用域中的数据,此时可以直接使用requestScope变量来获取对应的数据,requestScope本质上就是一个Map对象,里面保存了当前HTTP请求中的可用数据。如下所示:
案例代码如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>JSP四大作用域requestScope</title>
</head>
<body>
<h3>JSP四大作用域requestScope</h3>
${requestScope.getOrDefault("username", "Default_value")}
</body>
</html>
1.3、sessionScope
session作用域:session是一个HttpSession会话对象,它里面保存的数据作用范围是当前这次会话,也就是从浏览器打开到浏览器关闭这一个过程中,都可以访问到session中保存的数据,或者说在session失效之前,都可以获取session作用域中的数据。要想保存数据到session作用域里面,只需要调用HttpSession会话对象的setAttribute()方法即可。
如果我们使用的是EL表达式来获取session作用域中的数据,此时可以直接使用sessionScope变量来获取对应的数据,sessionScope本质上就是一个Map对象,里面保存了当前session会话中的可用数据。如下所示:
案例代码如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>JSP四大作用域sessionScope</title>
</head>
<body>
<h3>JSP四大作用域sessionScope</h3>
${sessionScope.getOrDefault("username", "Default_value")}
</body>
</html>
1.4、applicationScope
application作用域:application是一个ServletContext上下文对象,它里面保存的数据是在整个Web应用程序运行期间都生效的,也就是说,从Web应用程序启动到停止这段时间里面,都可以访问到application作用域中保存的数据,它的作用范围是最大的。要想保存数据到application作用域里面,只需要调用ServletContext上下文对象的setAttribute()方法即可。
如果我们使用的是EL表达式来获取application作用域中的数据,此时可以直接使用applicationScope变量来获取对应的数据,applicationScope本质上就是一个Map对象,里面保存了当前Web应用程序中的可用数据。如下所示:
案例代码如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>JSP四大作用域applicationScope</title>
</head>
<body>
<h3>JSP四大作用域applicationScope</h3>
${applicationScope.getOrDefault("username", "Default_value")}
</body>
</html>
从上面可以看出,其实每个作用域本质上都是一个Map对象,只不过这个Map对象中的数据可以在哪些范围里面访问是不一样的。
今天就到这里,未完待续~~
猜你喜欢
- 2024-10-27 从bitmap到布隆过滤器,再到高并发缓存设计策略
- 2024-10-27 强大 WebView2 + 不用写 JavaScript 的 htmx.js 「小轻快」开发桌面程序
- 2024-10-27 Java,FreeMarker,模板引擎,通过案例代码,学懂模板引擎
- 2024-10-27 面向对象的三大特性(c++面向对象的三大特性)
- 2024-10-27 教你分析9种 OOM 常见原因及解决方案
- 2024-10-27 可动态调节参数的线程池实现(动态调试工具有哪些)
- 2024-10-27 Java,基本类型和引用类型,强引用、软引用、弱引用、虚引用
- 2024-10-27 深入理解Java:类加载机制及反射(java常见类加载器)
- 2024-10-27 JVM系列-6.javap指令介绍(jvm调优)
- 2024-10-27 Java 泛型使用(类、方法、接口协议、类型通配符、通配符上下限)
- 1517℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 594℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 521℃MySQL service启动脚本浅析(r12笔记第59天)
- 489℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 489℃启用MySQL查询缓存(mysql8.0查询缓存)
- 477℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 456℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 454℃MySQL server PID file could not be found!失败
- 最近发表
-
- PS所有滤镜的说明(六)(ps滤镜详解)
- 5款小白也能用的在线图片编辑器!电商效率飙升就靠它!
- Java变量(java变量有什么作用)
- Java面试常见问题:Java注解(java中的面试题)
- Java编程入门第一课:HelloWorld(java编程从入门到实践)
- Java基础教程:Java继承概述(java里继承的概述)
- java基础之——访问修饰符(private/default/protected/public)
- 如何规划一个合理的JAVA项目工程结构
- 将机器指令翻译成 JavaScript -- 终极目标
- Web 服务器基准测试:Go vs. Node.js vs. Nim vs. Bun
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)