hibernate+spring mvc, 解决hibernate 对象懒加载 json序列化问题

引用地址

在使用Spring MVC时,@ResponseBody 注解的方法返回一个有懒加载对象的时候出现了异常,以登录为例:

 

Java代码  收藏代码
  1. @RequestMapping("login")  
  2.     @ResponseBody  
  3.     public Object login(@RequestParam String username,@RequestParam String password){  
  4.         List<User> list=userDAO.findByUsername(username);  
  5.         if(list.size()>0){  
  6.             User user=list.get(0);  
  7.             if(user.getPassword().equals(password)){  
  8.                 return new Result(user, "操作成功", true);  
  9.             }else{  
  10.                 return new Result(null, "密码错误", true);  
  11.             }  
  12.         }else{  
  13.             return new Result(null, "用户未注册", false);  
  14.         }  
  15.     }  

 客户端抛出org.hibernate.LazyInitializationException异常。通过查询资料和摸索整理出三种解决方法:

第一种:(推荐)

在web.xml中加入:

Xml代码  收藏代码
  1. <filter>  
  2.         <filter-name>openSession</filter-name>  
  3.         <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>  
  4.         <init-param>  
  5.             <param-name>singleSession</param-name>  
  6.             <param-value>false</param-value>  
  7.         </init-param>  
  8.     </filter>  
  9.     <filter-mapping>  
  10.         <filter-name>openSession</filter-name>  
  11.         <url-pattern>/*</url-pattern>  
  12.     </filter-mapping>  

 这样返回的Spring mvc返回的Json串也包含一对多关系中的对象,不过都是空的。

Js代码  收藏代码
  1. {"message":"操作成功","results":{"language":null,"id":"402881e6421e40b601421e4111c60001","type":null,"extra":null,"time":null,"username":"wanggang","msg":null,"password":"138333","tag":null,"tel":null,"qq":null,"email":null,"gender":null,"lat":null,"lang":null,"point":null,"openid":null,"city":null,"photo":null,"notes":[],"chatsForUserTwoId":[],"attentionsForUserId":[],"attentionsForAttentionUserId":[],"logs":[],"chatsForUserOneId":[],"commentsForNoteId":[],"commentsForUserId":[]},"success":true}  

 第二种方法(推荐):

在一对多的关系中加@JsonIgnore,这样Jackson在转换的时候就会过滤掉这个对象:

Java代码  收藏代码
  1. @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "user")  
  2. @JsonIgnore  
  3. public Set<Log> getLogs() {  
  4.     return this.logs;  
  5. }  
  6.   
  7. public void setLogs(Set<Log> logs) {  
  8.     this.logs = logs;  
  9. }  

 第三种方式:

把fetch模式配置成“FetchType.EAGER”,这样的方式可以解决问题,但是这样的方式会强制提取一对多关系中的数据,生成很多无用数据,也会增加系统负担,所以不建议采用。

Java代码  收藏代码
  1. @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER, mappedBy = "user")  
  2.     public Set<Log> getLogs() {  
  3.         return this.logs;  
  4.     }  
  5.   
  6.     public void setLogs(Set<Log> logs) {  
  7.         this.logs = logs;  
  8.     }  

其实还有一种方法,就是jsonignore注解方法

posted @   Seaurl  阅读(353)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示