posts - 40,  comments - 187,  trackbacks - 0

          開發環境:
          Struts 1.2 + Spring 1.2.8 + Hibernate 3.2

          遇到的問題:
          org.hibernate.LazyInitializationException: could not initialize proxy - the owning Session was closed
          ?at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:60)
          ?at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:111)
          ?at org.hibernate.proxy.pojo.cglib.CGLIBLazyInitializer.invoke(CGLIBLazyInitializer.java:172)
          ?at com.zhjy.gea.module.affair.domain.Affair$$EnhancerByCGLIB$$e10be950.getAffairCatalogs(<generated>)
          ?at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
          ?at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
          ?at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
          ?at java.lang.reflect.Method.invoke(Method.java:585)
          ?at org.apache.commons.beanutils.PropertyUtilsBean.invokeMethod(PropertyUtilsBean.java:2049)
          ?at org.apache.commons.beanutils.PropertyUtilsBean.getSimpleProperty(PropertyUtilsBean.java:1286)
          ?at org.apache.commons.beanutils.BeanUtilsBean.copyProperties(BeanUtilsBean.java:284)
          ?at org.apache.commons.beanutils.BeanUtils.copyProperties(BeanUtils.java:137)

          分析原因:
          由于Spring控制的Hibernate的生命周期只針對數據層和服務層,而未管理到表現層,所以會出現the owning Session was closed的現象。針對這一點,我通過hibernate filter的方式來解決。

          解決方法:
          在web.xml中配置filter來解決。

          <!-- ?hibernate?session?filter? -->
          ?
          < filter >
          ??
          < filter-name > hibernateFilter </ filter-name >
          ??
          < filter-class > ???org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
          ??
          </ filter-class >
          ?
          </ filter >

          < filter-mapping >
          ??
          < filter-name > hibernateFilter </ filter-name >
          ??
          < url-pattern > *.do </ url-pattern >
          ?
          </ filter-mapping >


          記于此處,望遇到同樣問題的朋友,少走彎路。:)

          ??????????????????????????????????????????????????????????????????? THE END
          posted on 2007-07-23 18:31 小立飛刀 閱讀(4374) 評論(3)  編輯  收藏 所屬分類: Hibernate

          FeedBack:
          # re: Hibernate不聽話了-- could not initialize proxy - the owning Session was closed
          2007-07-24 15:14 | 一條老狗
          另外,也可以在Service 或者 dao 層把lazy的Hibernate.initialize強制加載它。這樣在視圖層就不會出現session已關閉的錯誤了。
          當然,這樣似乎lazy就沒有意義了。
          視具體情況而定吧。

            回復  更多評論
            
          # re: Hibernate不聽話了-- could not initialize proxy - the owning Session was closed
          2007-07-24 15:25 | 小雪飛刀
          @一條老狗
          您說的情況比如在編輯頁面里面lazy=true,而在瀏覽頁面lazy=false,這樣可以在需要lazy的地方才進行控制。但是配置文件中Lazy屬性是控制全局的。這時就需要用到Hibernate.initialize(Object proxy) 方法。
          在配置文件里面可以用lazy=true,在程序里面可以用強制加載的方法Hibernate.initialize(Object proxy) 方法強制加載這樣就相當于動態改變為lazy=false。
          但有一點需要注意的是,proxy是持久對象的關聯對象屬性,如要把實體A的關聯實體B也取出時,就要寫Hibernate.initialize(a.b)。  回復  更多評論
            
          # re: Hibernate不聽話了-- could not initialize proxy - the owning Session was closed
          2007-07-24 18:05 | 一條老狗
          lazy 不是全局的,可以單個配置。  回復  更多評論
            
          <2007年7月>
          24252627282930
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          生存或毀滅,這是個必答之問題:是否應默默的忍受坎苛命運之無情打擊,還是應與深如大海之無涯苦難奮然為敵,并將其克服。此二抉擇,究竟是哪個較崇高?

          常用鏈接

          留言簿(12)

          隨筆分類(43)

          相冊

          收藏夾(7)

          朋友的博客

          電子資料

          搜索

          •  

          積分與排名

          • 積分 - 302763
          • 排名 - 192

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 鄂州市| 容城县| 胶州市| 普格县| 井研县| 怀仁县| 肇庆市| SHOW| 绥德县| 体育| 昌乐县| 德惠市| 平凉市| 双桥区| 沙洋县| 新竹市| 高青县| 博客| 桃源县| 郎溪县| 凤山市| 于都县| 斗六市| 桦南县| 寿光市| 大关县| 平山县| 栖霞市| 新建县| 炎陵县| 万山特区| 阳原县| 大城县| 西丰县| 永济市| 高邑县| 黄陵县| 垫江县| 惠州市| 桂东县| 壶关县|