request 、 session 和 globalsession 三种作用域仅在基于 Web 的应用中使用

Bean的singleton、prototype、request 、 session 和 globalsession五种作用域中,request 、 session 和 globalsession三种作用域仅在基于 Web 的应用中使用。

一般在 <bean> 标签中通过 scope 指定作用域类型,也可以在 <beans> 下指定默认全局的 scope 类型。

其中 Singleton 与 Prototype 类型的区别在于:Prototype 在交给用户后,IOC 容器不在具有管理权限,即放弃对该 bean 的生命周期管理。而 IOC 容器则会对 Singleton 进行完整的生命周期管理;Singleton 默认采用非延迟初始化,也可通过设置 lazy-init 属性改变初始化方式,但是 prototype 只能采用延迟初始化方式。</beans></bean>

Request作用域

考虑下面bean定义:

<bean id="loginAction" class="com.foo.LoginAction" scope="request"/>

针对每次HTTP请求,Spring容器会根据loginAction bean定义创建一个全新的LoginAction bean实例, 且该loginAction bean实例仅在当前HTTP request内有效,因此可以根据需要放心的更改所建实例的内部状态, 而其他请求中根据loginAction bean定义创建的实例,将不会看到这些特定于某个请求的状态变化。 当处理请求结束,request作用域的bean实例将被销毁。

简单的说,

scope=”request”

每次HTTP请求,Spring容器会根据所对应类创建一个全新的bean实例。这个对象实例只在当前request中有效。

 

Session作用域

考虑下面bean定义:

<bean id="userPreferences" class="com.foo.UserPreferences" scope="session"/>

针对某个HTTP Session,Spring容器会根据userPreferences bean定义创建一个全新的userPreferences bean实例, 且该userPreferences bean仅在当前HTTP Session内有效。 与request作用域一样,你可以根据需要放心的更改所创建实例的内部状态,而别的HTTP Session中根据userPreferences创建的实例, 将不会看到这些特定于某个HTTP Session的状态变化。 当HTTP Session最终被废弃的时候,在该HTTP Session作用域内的bean也会被废弃掉。

简单的说,

scope=”session”

每次HTTP session,Spring容器会根据所对应类创建一个全新的bean实例。这个对象实例只在当前HTTP session中有效。

 

global session作用域

考虑下面bean定义:

<bean id="userPreferences" class="com.foo.UserPreferences" scope="globalSession"/>

global session作用域类似于标准的HTTP Session作用域,不过它仅仅在基于portlet的web应用中才有意义。Portlet规范定义了全局Session的概念,它被所有构成某个portlet web应用的各种不同的portlet所共享。在global session作用域中定义的bean被限定于全局portlet Session的生命周期范围内。

请注意,假如你在编写一个标准的基于Servlet的web应用,并且定义了一个或多个具有global session作用域的bean,系统会使用标准的HTTP Session作用域,并且不会引起任何错误。

简单的说,

scope=”globalSession”

global session类似于HTTP Session作用域,它只有对portlet才有意义。对于Servlet的web应用就相当于session。

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring框架提供了一种称为“global session”的会话管理方式,它可以将多个HTTP请求绑定到同一个会话。这种会话管理方式通常用于处理用户登录、购物车等需要跨多个HTTP请求的场景,可以避免在每个HTTP请求都进行会话管理的开销和复杂性。 在Spring,全局会话作用域是通过`SessionScope`实现的。下面是一些详细的用法: 1. 配置全局会话作用域 在Spring配置文件添加如下配置: ```xml <bean class="org.springframework.web.context.support.SessionScope"> <aop:scoped-proxy/> </bean> ``` 这样就可以启用全局会话作用域了。 2. 在Bean定义使用全局会话作用域 使用全局会话作用域时,需要将Bean定义作用域设置为“session”: ```xml <bean id="myBean" class="com.example.MyBean" scope="session"> <!-- Bean属性配置 --> </bean> ``` 这样,每个会话都会有一个自己的`MyBean`实例。 3. 在Controller使用全局会话作用域 在Controller,可以使用`@SessionAttributes`注解来将模型属性存储到全局会话: ```java @Controller @SessionAttributes("myAttr") public class MyController { @ModelAttribute("myAttr") public MyAttr getMyAttr() { return new MyAttr(); } @RequestMapping("/myPage") public String myPage(Model model) { // 使用myAttr MyAttr myAttr = (MyAttr) model.asMap().get("myAttr"); // ... return "myPage"; } } ``` 在上面的示例,`@SessionAttributes`注解指定了“myAttr”属性,这样在调用`myPage`方法时,Spring会自动将`MyAttr`对象存储到全局会话,并将其添加到模型。 4. 获取全局会话 可以使用`RequestContextHolder`类来获取全局会话: ```java ServletRequestAttributes attr = (ServletRequestAttributes) RequestContextHolder.currentRequestAttributes(); HttpSession session = attr.getRequest().getSession(true); // true表示如果会话不存在,创建一个新会话 ``` 这样就可以获取当前线程的全局会话了。 总的来说,Spring的全局会话作用域提供了一种方便的会话管理方式,可以避免在多个HTTP请求之间进行会话管理的复杂性和开销。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值