Хобрук: Ваш путь к мастерству в программировании

Можно ли поместить все Application Services во внешний интерфейс в DDD?

Как я прочитал в некоторых статьях о проектировании, управляемом доменом, доменные службы должны обеспечивать логическую целостность домена и могут вызывать другие доменные службы для внешних вещей.

Итак, могу ли я предположить, что в веб-приложении с разделенными интерфейсом и сервером, даже если клиентская сторона неправдоподобна, пока доменные службы могут гарантировать, что ни одно бизнес-правило не будет нарушено, я могу поставить все службы приложений на передняя часть?

Если ответ «да», то разумно ли, что размещение всех служб приложений во внешнем интерфейсе поможет снизить нагрузку на сервер и упростить иерархию (поскольку самому внешнему интерфейсу нужен уровень служб), поскольку в нем не будет уровня служб приложений? серверная часть? Будут ли проблемы с безопасностью?


Ответы:


1

Вы можете и должны сделать прикладной уровень как можно более тонким и предотвратить любую утечку модели предметной области на прикладной уровень. Но я не думаю, что вы можете полностью удалить прикладной уровень из бэкенда, потому что вам нужно иметь там хотя бы некоторую логику сохранения.

06.03.2019
  • Должна ли логика постоянства находиться на прикладном уровне? Я новичок в ddd и довольно сильно запутался в деталях реализации. 09.03.2019
  • Да, все инфраструктурные проблемы, такие как постоянство, должны быть за пределами доменного уровня, который является прикладным уровнем. 09.03.2019
  • Согласно этим статьям reformedprogrammer.net / thereformedprogrammer.net/ , нет необходимости в уровне репозитория, поскольку логика постоянства может обрабатываться самими моделями предметной области. 10.03.2019
  • @Alsein в статье есть точка зрения исключения. Но большинство справочников по DDD, таких как Patterns, Principles and Practices of Domain-Driven Design, настоятельно не рекомендуют этого делать, потому что это нарушает принципы DDD. Модель домена просто обрабатывает логику домена и является реализацией UL. В нем не должно быть никаких технических проблем. Если вы удалите уровень репозитория, вы вставите логику постоянства внутри уровня домена, что сделает ваш бэкенд менее удобным для обслуживания. 06.12.2020
  • Новые материалы

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

    Как я опубликовал свое первое приложение в App Store в 13 лет
    Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..