gpt4 book ai didi

c# - 如何在业务逻辑层设计数据传输对象

转载 作者:可可西里 更新时间:2023-11-01 09:13:58 28 4
gpt4 key购买 nike

数据传输

我正在构建一个 Web 应用程序,我想扩展到许多用户。此外,我需要通过 Web 服务向受信任的第三方公开功能。

我正在使用 LLBLGen 生成数据访问层(使用 SQL Server 2008)。目标是构建一个业务逻辑层,使 Web 应用程序免受 DAL 细节的影响,当然,还提供 DAL 之外的额外验证级别。此外,据我所知,Web 服务本质上是 BLL 上的薄包装。

DAL 当然有自己的一组实体对象,例如 CustomerEntity、ProductEntity 等。但是,我不希望表示层直接访问这些对象,因为它们包含特定于 DAL 的方法并且程序集特定于 DAL 等等。因此,我们的想法是创建数据传输对象 (DTO)。这个想法是,这些本质上将是普通的旧 C#/.NET 对象,它们具有 CustomerEntity 的所有字段,实际上是数据库表 Customer 而不是其他任何东西,除了一些 IsChanged/IsDirty 属性。因此,会有 CustomerDTO、ProductDTO 等。我假设这些会继承自 DTO 基类。我相信我可以使用 LLBLGen 的一些模板生成这些,但我还不确定。

因此,想法是 BLL 将通过接受和返回这些 DTO 对象来公开其功能。我认为 Web 服务将为使用它的第三方处理将这些对象转换为 XML 的过程,许多人可能没有使用 .NET(另外,有些东西可以使用 JSON 从 Web 应用程序上的 AJAX 调用脚本调用)。

我不确定设计此内容的最佳方式以及前进的确切方式。以下是一些问题:

1) 这应该如何暴露给客户端(表示层和 Web 服务代码)

我在想会有一个具有这些方法的公共(public)类,每次调用都是一个原子操作:

InsertDTO、UpdateDTO、DeleteDTO、GetProducts、GetProductByCustomer 等等...

然后客户只需调用这些方法并传入适当的参数,通常是 DTO。

这是一个好的、可行的方法吗?

2) 从这些方法返回什么?显然,Get/Fetch 类方法将返回 DTO。但是插入呢?签名的一部分可以是:

InsertDTO(DTO dto)

但是,插入时应该返回什么?我想收到错误通知。但是,我对某些表使用了自动递增主键(但是,一些表具有自然键,尤其是多对多表)。

我想到的一个选项是结果类:

class Result
{
public Exception Error {get; set;}
public DTO AffectedObject {get; set;}
}

因此,在插入时,DTO 将获取其获取 ID(如 CustomerDTO.CustomerID)属性集,然后放入此结果对象中。如果 Result.Error != null,客户端将知道是否有错误,然后它将知道来自 Result.AffectedObject 属性的 ID。

这是一个好方法吗?一个问题是它似乎在来回传递大量冗余数据(当它只是 ID 时)。我不认为添加“int NewID”属性是干净的,因为一些插入不会有这样的自动递增键。另一个问题是我认为 Web 服务不能很好地处理这个问题?我相信他们只会在 Result 类中返回 AffectedObject 的基础 DTO,而不是派生的 DTO。我想我可以通过拥有大量不同类型的 Result 对象(可能从基础 Result 派生并继承 Error 属性)来解决这个问题,但这看起来不太干净。

好吧,我希望这不会太罗嗦,但我想说清楚。

最佳答案

1:这是一种非常标准的方法,非常适合“存储库”实现,以获得最佳的单元可测试方法。

2:异常(应该在 WCF 边界上声明为“故障”,顺便说一句)将自动引发。你不需要直接处理它。对于数据 - 共有三种常见方法:

  • 在合约上使用ref(不是很漂亮)
  • 返回(更新的)对象 - 即 public DTO SomeOperation(DTO item);
  • 只返回更新后的身份信息(主键/时间戳等)

关于所有这些的一件事是它不需要每个操作不同的类型(对比您的 Result 类,每个 DTO 都需要复制它)。

关于c# - 如何在业务逻辑层设计数据传输对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/574520/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com