【问题标题】:Breeze.js mixing DTOs and entitiesBreeze.js 混合 DTO 和实体
【发布时间】:2014-03-28 10:49:03
【问题描述】:

在沃德的文章“The Breeze Server: Have It Your Way”中:

典型的业务应用至少有 200 个领域模型 类型。 90% 以上的时间是我通过 线与我的业务模型中实体的形状相同。
...
当客户实体的形状与客户实体的形状不一致时 服务器端业务实体,我可能会为此切换到 DTO 特殊情况。

这对我们的应用程序来说是一针见血,但是为 DTO 仅切换 一些 实体的最佳方法是什么?

例如,我们的 User 实体包含不应向客户端公开的敏感属性。它还具有从其他系统中提取并返回给客户端的相关数据,理想情况下,这些数据应该只是客户端用户对象上的额外属性。用户似乎是切换到 DTO 的理想人选。

如果用户是一个孤立的实体,这可能会更容易,但问题是用户在模型中基本上无处不在。例如,几乎每个实体都有一个 CreatedBy 属性。

有没有办法在模型中的任何地方为用户 DTO 切换用户实体?对于模型中引用用户的所有其他实体,我们仍然需要能够在扩展其用户属性的情况下加载它们,在这些用户属性上查询它们,并在对这些用户属性进行更改时保存它们。

除了构建一个与实体模型 95% 相同的大型 DTO 模型之外,我不知道该怎么做,并且在它们之间有一些映射代码/框架。但是,正如 Ward 在 this post 中所说的那样,“我不喜欢所有类型的 DTO;这太过分了,会破坏生产力。”

【问题讨论】:

  • 我对混合 dto 和真实实体感兴趣。你有那个场景的工作样本吗?特别是,您如何对元数据进行 dto 处理?

标签: entity-framework breeze dto


【解决方案1】:

你们相处得很好。像这样的问题堆积如山。我希望“尽快”提供更好的指导。

在短期内(假设您是 .NET 开发人员),您可能会在 DocCode 示例中找到一些线索。搜索“ProductDto”。 DocCode 没有显示您如何保存对它的更改,所以我将不得不推迟到另一个时间。

您的情况实际上可能很容易解决。

第 1 步:使用自定义 DbContext

首先编写您的业务模型DbContext 的子类。向这个子类添加一个覆盖到您的 OnModelCreating 并教它忽略不应成为模型一部分的 User 属性。

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
   modelBuilder.Entity<User>().Ignore(u => u.whatever);
   ...
   base.OnModelCreating(modelBuilder);
}

现在在与客户交流时参考这个派生的DbContext

请注意,这涉及非常少量的代码并且易于维护。它不会干扰您使用基础DbContext,它保留对User 的所有属性的完全访问权限。

步骤 #2:配置 JSON.NET 以从序列化中排除这些属性

关注James Newton King's guidance。如果您不想使用 [JsonIgnore] 属性来装饰/污染您的 User 类,请特别查看 IContractResolver。 James 是 JSON.NET 的作者。

【讨论】:

  • 保存更改是有趣的部分,所以“更好的指导”会很有帮助!
  • 确实! :-)。简而言之:(1) 从EntityInfos 中删除 DTO,(2) 从 Db 中检索相应的业务模型实体(如果这是插入,则创建这样的实体),(3) 从 DTO 更新此副本,(4) 添加此实体到EntityInfos (不要忘记OriginalValues 属性进行更新),(5)冲洗并重复所有此类DTO,(6)放手......EF会保存它,(7)拦截“保存后”并将更新/插入的业务实体重新映射到SaveResult 中的 DTO 形式,以便您将 DTO,而不是“真实”实体发送​​回客户端。我敢肯定,细节是魔鬼。
  • @Ward - 这适用于使用 Database First 的 EF 设置吗?该方法被覆盖: throw new UnintentionalCodeFirstException();
  • @user210757 - 你有没有解决过UnintentionalCodeFirstException 的问题?
猜你喜欢
  • 2021-06-16
  • 1970-01-01
  • 2012-11-28
  • 1970-01-01
  • 1970-01-01
  • 2020-07-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多