在域模型对象中使用工厂?

时间:2010-01-20 14:59:14

标签: java hibernate spring dependency-injection inversion-of-control

情景:

在我的应用程序中(使用富域模型,逻辑在模型中,而不在服务中)我有用户。我使用服务创建新用户

User newUser = userService.createNewUser("Hans Dampf");

或从数据库中获取

User oldUser = userDao.findByName("Hans Dampf");

因为在每次调用我的应用程序时都可以直接访问用户对象,所以我想将用户对象用作我的域模型的入口点。

每个用户可以拥有不同类型的图库,保存在另一个表格中。

class User {
 @OneToMany(fetch = FetchType.LAZY)
 @JoinColumn(name = "userId")
 private Set<Gallery> automatic = new HashSet<Gallery>();
}

我希望有一种简单的方法来启用特定的图库。所以我的API看起来像:

User user = ... // creating or retriving user
user.enableMainGallery();

在这个方法中,创建一个新的图库对象并将其添加到图库列表是必要的。但是如何创建这个新实例呢?用工厂?这需要将工厂注入域对象(可能有问题)。

public void enableAutomaticGallery() {
    automatic.add(automaticFactory.createAutomaticGallery(this));
}

或者我的界面定义有缺陷吗?我应该以其他方式定义它,这样我就不必注入工厂了吗?怎么样?

2 个答案:

答案 0 :(得分:1)

正如您所说,域对象不应该依赖于应用程序级对象,例如工厂或Daos。

域通常是:

  • 复杂 - 足够满足功能需求,无需添加其他问题(如持久性,验证,GUI等......)
  • 中心并随处使用(因此复杂性会影响您在许多编码活动中的工作效率)
  • 可重复使用跨相关应用程序,在所有层中,甚至可以序列化并发送到客户端或WebService上的不同JVM(除非它依赖于应用程序级对象)

因此,您的enableAutomaticGallery方法应该位于Service对象上。 它可以具有相同的代码,但与应用程序有关。

答案 1 :(得分:1)

您的域模型应该对任何服务或DAO层甚至任何工厂对象都不了解。

我建议使用方法User.enableMainGallery()而不是需要将Gallery个对象添加到实例集合中(正如您所说的),而是公开方法User.addGallery(Gallery)

这样,负责“启用图库”的类通过向 list 集合中添加对象来实现。

换句话说,我不相信User对象应该负责知道“启用主库”意味着什么。这听起来像属于商业逻辑的umbrealla(模糊的术语,我知道)。