情景:
在我的应用程序中(使用富域模型,逻辑在模型中,而不在服务中)我有用户。我使用服务创建新用户
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));
}
或者我的界面定义有缺陷吗?我应该以其他方式定义它,这样我就不必注入工厂了吗?怎么样?
答案 0 :(得分:1)
正如您所说,域对象不应该依赖于应用程序级对象,例如工厂或Daos。
域通常是:
因此,您的enableAutomaticGallery
方法应该位于Service对象上。
它可以具有相同的代码,但与应用程序有关。
答案 1 :(得分:1)
您的域模型应该对任何服务或DAO层甚至任何工厂对象都不了解。
我建议使用方法User.enableMainGallery()
而不是需要将Gallery
个对象添加到实例集合中(正如您所说的),而是公开方法User.addGallery(Gallery)
。
这样,负责“启用图库”的类通过向 list 集合中添加对象来实现。
换句话说,我不相信User
对象应该负责知道“启用主库”意味着什么。这听起来像属于商业逻辑的umbrealla(模糊的术语,我知道)。