细说OpenSessionInView问题
【环境参数】
环境:SSH框架
【问题描述】
NoSession问题
HibernateTemplate对象提供的方法如果使用“延迟加载”,Session对象的管理不受开发者控制,此时如果在表现层获取延迟加载的数据,
则会抛出“LazyInitializationException”异常,如下图所示。
【原因分析】
原因总结:Session的存活期太短,在Session已经关闭的情况下,App读取持久化对象中的非OID的属性从而报错。
假设load()方法获得的对象是User对象。
“延迟加载”的特点:
在Hibernate没有关闭Session时,App可以随时去读取“延迟数据(通过让Hibernate重新加载去获得数据)”。
load()方法获得的User对象是一个“只有ID属性”的对象,只要App不去使用User对象中的“非ID属性”,则User对象中永远都只有ID属性,这样可以提高性能。
当App去调用对象X中的非ID属性时,比如name和age属性,正常情况下,Hibernate会去加载name和age属性,然后JVM再调用toString()方法,并且成功地完成打印。
但若在Hibernate去加载name和age属性时,Session已经关闭了,则Hibernate就无法去加载得到非ID属性了,此时就会抛出异常“LazyInitializationException”。
Session为什么会关闭呢?
当我们提交事务时,就会自动把Session给关闭了。
【解决方案】
该解决方案由Spring提供:OpenSessionInView。
(1)主要思路
将Session的存活期延长,绑定Session。
(2)产生该方案的思路
客户端发一个请求,则位于服务器端的Spring创造一个Session,当请求结束了,才会把Session关闭,这样,就将Session与请求绑定在一起了。
从发送请求到请求结束,这整个流程都位于一个线程,在此,将Session对象绑定到该线程上,在Hibernate知识体系中,就有一个关于“当前线程绑定Session”的专题,讲的也就是这个概念。
客户端每次发送请求时,都要去将Session绑定到线程上,这样比较麻烦,能否有简化途经呢?比如Spring的AOP。
1)可选方案一:利用Spring的AOP。
方案一可行性:不靠谱。
为什么方案一不行?
因为在客户端发送的请求在到达服务器的过程中,Spring还没有开始工作。Spring若想绑定东西,要绑定的东西必须是“代码”,
“请求对象和响应对象的创建”是由服务器端的HTTPD守护程序完成的。而Spring是位于Web容器中的,而且Spring容器随着某个WebApp的启动而创建的。此时Spring还没有开始工作,而请求对象已经被HTTPD守护程序创建了,此时,Spring是不可能将Request对象同Session对象进行绑定的,因此,AOP是不能完成该功能的。
2)可选方案二:利用监听器
方案二可行性:不靠谱。
<listener>监听器:监听器是启动服务器时一次性运行的。
3)可选方案三:利用过滤器
<filter>过滤器:过滤器是每当用户的请求Request对象到达WebApp时以及Response对象出WebApp时使用的。
(3)终极解决方案
1)简述:OpenSessionInView翻译过来就是:在表现层打开Session。
2)作用:
将Session对象的创建交给当前线程管理,当前线程维护着一个“Session的连接池”。每当用户发送一个请求,filter在接收到用户的请求Request后,就会将Session对象绑
定到该请求上。
当请求被处理完毕,返回响应Response时,Response会再次经过filter的处理,Response之前被绑定的Session会被filter回收,然后放入到“Session的连接池”中。
当下次用户再次发送请求时,仍然重复上述过程。
3)代码:
在web.xml中设置过滤器OpenSessionInViewFilter。
<!-- 配置OpenSessionInView -->
<filter>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
读者如要转载,请标明出处和作者名,谢谢。
地址01:http://space.itpub.net/25851087
地址02:http://www.cnblogs.com/zjrodger
作者名:zjrodger
细说OpenSessionInView问题的更多相关文章
- [转]细说OpenSessionInView问题
转载:https://www.cnblogs.com/zjrodger/p/4615809.html. [环境参数] 环境:SSH框架 [问题描述] NoSession问题 HibernateTem ...
- 匹夫细说C#:庖丁解牛迭代器,那些藏在幕后的秘密
0x00 前言 在匹夫的上一篇文章<匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置>的最后,匹夫以总结和后记的方式涉及到一部分迭代器的知识.但是觉得还是不够过瘾,很多需要说清楚 ...
- 细说WebSocket - Node篇
在上一篇提高到了 web 通信的各种方式,包括 轮询.长连接 以及各种 HTML5 中提到的手段.本文将详细描述 WebSocket协议 在 web通讯 中的实现. 一.WebSocket 协议 1. ...
- 匹夫细说C#:委托的简化语法,聊聊匿名方法和闭包
0x00 前言 通过上一篇博客<匹夫细说C#:庖丁解牛聊委托,那些编译器藏的和U3D给的>的内容,我们实现了使用委托来构建我们自己的消息系统的过程.但是在日常的开发中,仍然有很多开发者因为 ...
- 细说Java主流日志工具库
概述 在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息. 在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子. 我们先来逐一了解一下主流日志工具. java.util ...
- 细说 Form (表单)
细说 Form (表单) Form(表单)对于每个WEB开发人员来说,应该是再熟悉不过的东西了,可它却是页面与WEB服务器交互过程中最重要的信息来源. 虽然Asp.net WebForms框架为了帮助 ...
- 细说ASP.NET Forms身份认证
阅读目录 开始 ASP.NET身份认证基础 ASP.NET身份认证过程 如何实现登录与注销 保护受限制的页面 登录页不能正常显示的问题 认识Forms身份认证 理解Forms身份认证 实现自定义的身份 ...
- 细说CSS选择器
众所周知,CSS的一个核心特征就是能向文档中的一组元素类型应用某些规则.每个规则都有两个基本部分:选择器(selector)和声明块(declaration block).下图显示了规则的各个部分. ...
- [转]细说Redis监控和告警
原文 https://zhuoroger.github.io/2016/08/20/redis-monitor-and-alarm/? 对于任何应用服务和组件,都需要一套完善可靠谱监控方案. 尤其r ...
随机推荐
- HDU 3433 (DP + 二分) A Task Process
题意: 有n个员工,每个员工完成一件A任务和一件B任务的时间给出,问要完成x件A任务y件B任务所需的最短时间是多少 思路: DP + 二分我也是第一次见到,这个我只能说太难想了,根本想不到. dp[i ...
- HDU 2144 (最长连续公共子列 + 并查集) Evolution
我发现我一直理解错题意了,这里的子序列指的是连续子序列,怪不得我写的LCS一直WA 顺便复习一下并查集 //#define LOCAL #include <iostream> #inclu ...
- BZOJ 3653 谈笑风生
ORZ blutrex...... 主席树. #include<iostream> #include<cstdio> #include<cstring> #incl ...
- 几个排序算法的JS实现
最近找工作,复习一下数据结构的知识,看到排序这一块,顺便动手改了一下. 直接插入排序: 插入排序就是把数据分为有序区和无序区,遍历到的数据和有序区域的数据进行比较,找到要插入的位置,插入位置后的数据做 ...
- HDU 2577 How to Type (DP,经典)
题意: 打字游戏,求所按的最少次数.给出一个串,其中有大小写,大写需要按下cap键切换到大写,或者在小写状态下按shift+键,这样算两次,打小写时则相反.注意:在打完所有字后,如果cap键是开着的, ...
- VPN协议PPTP/L2TP/OpenVPN及SSH的区别与详解
大家在使用VPN的时候都会看到商家有提供PPTP VPN.L2TP VPN.OpenVPN.SSH代理等多种协议选择,但是许多朋友却不知道它们之间有什么区别,也不知道该如何选择,今天整理了一些日常收 ...
- Oracle buffer cache与相关的latch等待事件
buffer cache与相关的latch等待事件 1.buffer cache 2.latch:cache buffers lru chain 3.latch:cache buffers chain ...
- MySQL与Oracle 差异比较之五存储过程&Function
存储过程&Function 编号 类别 ORACLE MYSQL 注释 1 创建存储过程语句不同 create or replace procedure P_ADD_FAC( id_fac ...
- 【转】WPF MultiBinding 和 IMultiValueConverter
WPF MultiBinding 和 IMultiValueConverter 时间 2015-02-02 19:43:00 博客园精华区 原文 http://www.cnblogs.com/wo ...
- [转] C# 键盘中的按键对应的KeyValue
原文C#KeyValue对应键盘 首先先看一下什么情况下需要对按键进行识别: KeyPress事件响应函数中,有KeyPressEventArgs, 对应于e.KeyChar; KeyDown事件响应 ...