在最近关于(核心)Spring Framework的培训课程中,有人问我:“(Java)Spring开发人员是否应该知道一件事,那应该是什么?” 这个问题使我措手不及。 是的,(核心)Spring框架确实涵盖了很多领域(例如,bean,配置,面向方面的编程,事务)。 我很难指出一件事。 最后,我提到了我们为期3天的培训课程所涵盖的所有内容。

如果(Java)Spring开发人员应该知道的一件事,那应该是什么?

当我进一步思考这个问题时,我开始思考重要的一个问题。 最后,我想到了Spring如何重要地使用方面将行为添加到托管对象(通常称为bean)中。 Spring Framework通过这种方式来支持事务,安全性,范围,基于Java的配置等。 我在这篇文章中分享我的想法。

最后,我想到了Spring如何重要地使用方面将行为添加到托管对象(通常称为bean)中。

ORM和延迟加载异常

大多数使用某种形式的ORM的开发人员都遇到了一个异常,该异常表明无法加载子实体(例如LazyInitializationException )。

一些遇到这种情况的开发人员将使用“打开的视图中的会话”( OSIV )模式来保持会话打开并防止发生此异常。 但是我觉得这太过分了。 更糟糕的是,一些开发人员认为“开放会话可见”模式是唯一的解决方案。 造成这种误解的潜在根本原因可能是,开发人员可能不了解有效使用Spring Framework来保持ORM会话打开时间更长的知识。

对于JPA ,“打开视图中的实体管理器”模式将在请求开始时创建一个实体管理器,将其绑定到请求线程,并在响应完成时将其关闭。

那么,如果不是OSIV模式,哪种解决方案更好?

简短的答案是使用Spring框架在需要的时间内保持会话打开(例如@Transactional )。 请继续阅读,因为我会提供更长的答案。

服务和存储库

在分层体系结构中,典型的设计模式是定义域或应用程序服务 (通常定义为接口)以提供业务功能(例如,开始使用购物车,向该购物车添加商品,搜索产品)。 域和应用程序服务的实现通常会将域实体的检索/持久性委派给存储库。

存储库 (或数据访问对象)也被定义为检索/持久化域实体(即提供ORM和CRUD访问)的接口。 自然地,存储库实现使用ORM库(例如JPA / Hibernate,myBATIS)来检索和持久化域实体。 这样,它使用ORM框架的类连接到持久性存储,检索/持久化实体并关闭连接(在Hibernate中称为会话)。 此时,没有延迟加载失败的问题。

当服务使用资料库中检索域实体,并希望加载的子实体(库方法返回之后 )发生的懒加载失败问题。 到存储库返回域实体时,ORM会话将关闭。 因此,尝试访问/加载域服务中的子实体会导致异常。

下面的代码段说明了当订单实体的子项目由存储库返回后被延迟加载时,如何发生延迟加载异常。

@Entity
public class Order {@OneToMany // defaults to FetchType.LAZYprivate List<OrderItem> items;…public List<OrderItem> getItems() {…}
}public class SomeApplicationServiceImpl implements SomeApplicationService {private OrderRepository orderRepository;…@Overridepublic void method1(…) {…order = orderRepository.findById(...);order.getItems(); // <-- Lazy loading exception occurs!…}…
}public class OrderRepositoryImpl implements OrderRepository {@PersistenceContextprivate EntityManager em;…@Overridepublic Order findById(...) {...}…
}

存储库实现将JPA明确用于其ORM(如使用EntityManager )。

在这一点上,一些开发人员可能选择使用紧急获取来防止延迟初始化异常。 告诉ORM急切地获取订单实体的子项将起作用。 但是有时候,我们不需要加载子项。 急于加载它可能是不必要的开销。 仅在需要时加载它会很棒。

为了防止延迟初始化异常(而不是被迫急于获取),我们需要保持ORM会话打开,直到调用服务方法返回。 在Spring中,可以像@Transactional一样简单地注释服务方法以保持会话打开。 我发现这种方法比使用“在视图中打开会话”模式(或被迫使用急切获取)更好,因为它使会话仅在我们希望的时间内保持打开状态。

public class SomeApplicationServiceImpl implements SomeApplicationService {private OrderRepository orderRepository;…@Override@Transactional // <-- open the session (if it's not yet open)public void method1(…) {…order = orderRepository.findById(...);order.getItems(); // <-- Lazy loading exception should not happen…}…
}

表示层中的域实体

即使将ORM会话在服务层中(在存储库实现对象之外)保持打开状态,当我们将域实体暴露给表示层时,仍然可能发生惰性初始化异常。 同样,由于这个原因,一些开发人员更喜欢OSIV方法,因为它还可以防止表示层中的延迟初始化异常。

但是,为什么要在表示层中公开域实体?

根据经验,我曾与那些希望在表示层中公开域实体的团队合作。 这通常会导致贫血领域模型 ,因为表示层框架需要一种将输入值绑定到对象的方法。 这迫使域实体具有getter和setter方法以及零参数构造函数。 具有getter和setter将使不变式难以执行。 对于简单域,这是可行的。 但是对于更复杂的领域,更丰富的领域模型将是首选,因为它更易于实施不变式。

在更丰富的域模型中,表示表示层输入/输出值的对象实际上是数据传输对象(DTO)。 它们代表在域层中执行的输入(或命令)。 考虑到这一点,我更喜欢使用DTO并维护更丰富的域模型。 因此,我并没有真正在表示层遇到懒惰的初始化异常。

向受管对象添加行为的方面

Spring会拦截对这些@Transactional注释方法的调用,以确保ORM会话处于打开状态。

事务(或只是保持ORM会话保持打开状态)并不是使用方面提供的唯一行为。 有安全性,范围,基于Java的配置等。 知道Spring框架使用方面来添加行为是我们让Spring管理我们开发的POJO的关键原因之一。

结论

妳去 对我来说,这是Spring Framework开发人员在使用内核时应了解的最重要件事。 现在,我已经对什么是最重要的事情发表了意见,您呢? 在处理Core Spring时,您认为最重要件事是。 干杯!

翻译自: https://www.javacodegeeks.com/2016/02/one-thing-good-spring-developers-know.html

Spring开发人员知道的一件事相关推荐

  1. spring一站式开发_Spring开发人员知道的一件事

    spring一站式开发 在最近的(核心)Spring框架培训课程中,有人问我:"(Java)Spring开发人员应该知道的一件事是什么?" 这个问题使我措手不及. 是的,(核心)S ...

  2. Spring Security可以做的十件事

    一 您可以在Spring XML配置文件中指定您选择的授权提供者. 您可以通过配置Spring的http://www.springframework.org/schema/security/sprin ...

  3. 我怎么看技术人员去创业公司这件事

    我怎么看技术人员去创业公司这件事. 当前,创业风潮席卷而来,很多人也会受到这个吸引和影响.分享一下我是怎么看这件事的.首先,我不会阻止你,因为大家有更好的机会,更多的薪水,我会为你高兴,你不去,我还得 ...

  4. Dynamics CRM技术开发应该知道的十件事(上)

    Dynamics CRM技术开发应该知道的十件事 1.web资源引入CSS或JS时使用相对路径 <link rel="stylesheet" type="text/ ...

  5. ChatGPT其实并不想让开发人员做这5件事情

    前言 ChatGPT已经火爆了快半年了吧,紧接着国内也开始推出了各种仿制品,我甚至一度怀疑,如果人家没有推出ChatGPT,这些仿制品会不会出现.而很多人也嗨皮得不行,利用各种方法开始科学上网,用Ch ...

  6. 软件开发最重要的十件事

    0. "面向对象"比你想象的要难得多 也许只有我有这种想法,不过我曾经以为计算机科学课上学过的"面向对象"是很简单的东西.我的意思是,创建一些类来模拟现实世界能 ...

  7. 2019年税收分类编码_通过分析112,654个编码测试,我们了解了2019年开发人员的招聘趋势...

    2019年税收分类编码 by Tom Winter 汤姆·温特(Tom Winter) 通过分析112,654个编码测试,我们了解了2019年开发人员的招聘趋势 (What we learned ab ...

  8. Java开发人员应该知道的5大Spring Boot功能

    您可能已经听说过Spring Boot,这是用不到140个字符创建一个Spring Web应用程序的神奇力量,可以在一条推文中编写这些字符,但这到底意味着什么? 哪些功能可以使Spring Boot具 ...

  9. 如何成为一名Web前端开发人员?入行学习完整指南

    经过如此多的试验和测试,而不是说你从头开始创建了所有内容,接着,你在网页上创建了第一个登录表单时,你感觉如何? 经过了多次更改后,将布局分配给第一个Web应用程序时感觉如何? 当成功处理了数千个用户的 ...

最新文章

  1. Android, BaseAdapter 处理大数据量时的优化
  2. 最新的ES 5.0路由算法底层实现
  3. 《CCNP TSHOOT 300-135认证考试指南》——5.4节STP故障检测与排除
  4. Android中ImageView常用属性含义
  5. 某教授对“中国式科研”的酒后真言
  6. Android下 布局加边框 指定背景色 半透明
  7. 2018最火机器学习项目盘点—CV项目领冠榜单
  8. Android 开发者的 RxJava 详解(一)
  9. WAV格式中常见的压缩编码
  10. Python学习---基础函数的学习
  11. ODAC(V9.5.15) 学习笔记(十六)直接访问模式
  12. 批量修改txt文件名,删除相同部分
  13. 【Python简明教程一】Python编程基础
  14. 商务与经济统计(13版,Python)笔记 01-02章
  15. matlab:蚁群算法原理的实现
  16. Ito‘s lemma伊藤引理
  17. kafka之broker
  18. linux镜像文件目录,Linux - 系统 - 文件目录
  19. 图谱实战 | 丁香园医疗领域图谱的构建与应用
  20. 达内C++视频(全)

热门文章

  1. Hibernate之必须导入jar包
  2. springboot项目不加端口号也可以访问项目的方法
  3. el表达式与jstl的用法
  4. css实现一级下拉菜单
  5. Github Pages + Jekyll 独立博客一小时快速搭建上线指南
  6. List实现类中调用下标删除VS调用元素删除
  7. Opencv FFmpeg Ubuntu下编译问题
  8. (转)mybatis热部署加载*Mapper.xml文件,手动刷新*Mapper.xml文件
  9. FAT12中,如何定位大于一个扇区(512B)的文件内容
  10. java 字符串文字筛选_重新开始Java的原始字符串文字讨论