Образцы контрактов данных SOA. Я уверен, что структура, которую я использую, вводит избыточность, кто-нибудь хочет меня просветить? - PullRequest
1 голос
/ 29 сентября 2010

Я начну так, как, кажется, привыкло большинство людей, здесь ...

Итак, я был ... Нет, вот и все.Я начну снова (может потерять несколько баллов за то, что не прямо, но wth)

Верно,

Я унаследовал инфраструктуру, которая использует WCF для обеспечения некоторых операций и контрактов данных,

Это может быть утомительно для некоторых, но я недостаточно изучил SOA или WCF, чтобы получить знания об эффективных шаблонах (или лучших практиках ...) и, следовательно, на самом деле не имею взвешенного мнения омоя команда по этому вопросу, на данный момент.

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

В частности, у нас есть следующие модели (контракты данных):

  • users_Loaded
  • users_Modify
  • users_Create

Для всех намерений и целей эти контракты данных абсолютно одинаковы - во многом, кроме своего «типа», они имеют одинаковые члены и свойства и т. Д., И в этом моя первая проблема.

Операции, использующие контракты данных, имеют параметры, которые соответствуют контракту данных, с которым вы, возможно, захотите выполнить какое-либо действие с

Таким образом, операции, использующие контракты данных:

  • CreateUser (users_Create createUser, ..., ...)
  • ModifyUser (users_Modify modifyUser, ..., ...)
  • GetUser (из users_Load загруженUser, .., ...) (выводить параметры в самой левой части списка параметров для загрузки !?)

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

Конечно, одного контракта данных было бы достаточно, и, может быть, даже одна операция (с параметром типа операции)

Я упускаю суть.Почему вы делаете то, что я описал?

Спасибо.

i

1 Ответ

1 голос
/ 29 сентября 2010

Похоже, что предыдущие разработчики (и) либо пытались реализовать какой-то неубедительный шаблон Command, либо они не понимали WCF.

Длинный ответ коротко, да, из того, что вы сказали,Вы должны просто отлично объединить их в класс UserDto, который является DataContract для всех трех операций.У svcutil, со своей стороны, не должно возникнуть проблем при создании одного класса DataContract на стороне клиента, который будет работать для всех трех методов OperationContract (или, поскольку вы, похоже, управляете обеими сторонами этого сервиса, просто используйте общую сборку, содержащую ваши DTO на обоихклиент и сервер).

...