gpt4 book ai didi

php - DDD - 实体创建和验证责任

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:36:26 28 4
gpt4 key购买 nike

最近几天对DDD(领域驱动设计)很感兴趣,但是搞不清楚实体的创建者和验证者的职责。我将打破这个问题以涵盖不同的场景。

  1. 常规实体(可能带有值对象)。作为一个例子,让我们以一个由电子邮件标识的用户为例。我有一个 UserFactory,它接收一组数据(可能来自 POST 表单),并向我返回一个新的 UserEntity。工厂是否应该验证数据的完整性(例如:作为电子邮件给出的字符串是真实的电子邮件,密码字段 1 和字段 2 中的密码匹配等)?工厂是否应该验证不存在这样的用户(我们不想用同一封电子邮件注册两个用户)?如果是,它应该自己完成还是使用 UserRepository?

  2. 聚合实体。假设我们有一个 Post 实体和 Comments 实体。我想获得 post 12 及其所有评论,所以我做了类似的事情

    $post = $postRepository->getById(12);

getById应该如何实现?像这样:

public function getById($id) {
$postData = $this->magicFetchFromDB($id);
$comments = (new CommentRepository())->getForPost(12);
return new PostEntity($postData, $comments);
}

或者可能是负责懒惰创建评论的帖子,例如:

class PostEntity {
public function getComments() {
if(is_null($this->_comments)) $this->_comments = (new CommentRepository())->getForPost($this->_id);
return $this->_comments;
}
}

?我在这里很迷茫,没有足够的信息来说明 PHP 中 DDD 的示例,因此我们将不胜感激!

非常感谢,skwee.

最佳答案

  • 工厂应该关心创建实体。我个人更喜欢在我的 View 和模型层中进行验证。我会使用一些像 jQuery 的验证插件这样的库在客户端进行一些必要的验证(比如检查必填字段是否有数据)。然后对模型进行“硬核”验证。 我这样做是通过使用所有实体都扩展的简单 BaseEntity 抽象类,并且由于您要求提供示例,因此它是:

    abstract class BaseEntity {
    public function isValid();
    }

    class MyEntity extends BaseEntity {
    public function isValid() {
    //actual validation goes here
    }
    }

    您还可以使用带有一些基本验证方法的静态帮助器类:

    class ValidationHelper {
    public static function isValidPhonenumber($value) {
    //check valid phonenumber, using a regex maybe
    }

    public static function isAlphanumeric($value) {
    //check for letters and numbers only
    }
    }

    许多人反对静态方法,因为它们会破坏单元测试,但在这种情况下,它们非常基本并且没有外部依赖性,因此使它们“更安全”。

  • 当谈到检查已经存在的实体时,您可以通过在添加/更新之前查询您的数据库以查看该实体是否已经存在来执行此操作,或者(这就是我喜欢的方式)您可以添加一个 unique 索引到那些在数据库中不能重复的列,然后将创建或更新查询包装在一个 try-catch block 中(如果两个用户,查询将抛出唯一约束冲突例如有相同的电子邮件)然后显示正确的错误消息

  • 关于您的最后一个问题,归结为偏好问题。如果您的数据库将在 1 分钟内获得一百万次点击,那么最好使用延迟加载来避免在需要时获取不必要的数据。但是,如果您的数据库相对较小,您可以完美地使用预先加载而不会牺牲太多性能。同样,这是个人喜好问题。

希望这些杂乱无章的内容有道理,干杯!

关于php - DDD - 实体创建和验证责任,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9161824/

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