从控制器(表示层)内映射域实体是否正确



我在Visual Studio 2015中有一个解决方案,我将DDD层作为项目分离。当我需要将数据从表示层(MVC 5)发送到应用层(类库)时,我通常使用:

应用程序服务

public interface IFooAppService
{
    void AddNew(string name, DateTime birthday);
}

控制器

[HttpPost]
public JsonResult AddNew(FooViewModel viewModel)
{
    FooAppService.AddNew(viewModel.Name, viewModel.birthday);
}

当我有一个包含许多属性和子实体的域实体类时,应用程序服务方法签名会变得太长。考虑到DDD和关注点的分离,在这种情况下,直接从MVC控制器将FooViewModel类映射到Foo域实体是否正确?这样的实施将是:

应用程序服务

public interface IFooAppService
{
    void AddNew(Foo foo);
}

控制器

[HttpPost]
public JsonResult AddNew(FooViewModel viewModel)
{
    Foo foo = FooMapper.Map(viewModel);
    FooAppService.AddNew(Foo);
}

将FooViewModel类映射到Foo域实体正确吗在这种情况下,是从MVC控制器来的吗?

如果你有一个应用程序服务,我会说没有。你麻烦创建一个额外的应用程序层,这样表示层就可以专注于做UI的事情,而不是直接处理域。仅仅因为"方法签名太长"就想短路,这似乎很奇怪。

此外,CQ(R)S命令的概念可以帮助您解决该参数问题。控制器可以调用应用程序服务,只传递一个命令。

如果您拥有的是从DTO到实体的简单映射,那么您可能正在构建一个贫血的域模型

您应该尝试使用DDD构建一个完整的域模型,或者使用CRUD风格的应用程序。根据应用程序的性质,这两种方法都很有用。DDD通常只对复杂的问题域有意义。

最新更新