我想知道通过WCF服务公开什么对象有什么意义 - 我应该将WCF序列化规范添加到我的业务实体,还是应该实现一个转换器,将我的业务实体映射到我希望通过我的WCF公开的DataContracts服务?
现在我有不同级别的实体:DataAccess,Business和Contract.我有适当的转换器,可以将实体从DataAccess映射到Business,从Business映射到Contract,反之亦然.实施和维护这些是耗时且相当繁琐的.与此相关的最佳做法是什么?
如果我使用的是OR/M,例如NHibernate或Entity Framework,我应该直接从ORM公开实体,还是应该像现在一样抽象它们?
提前致谢.
一般而言,我认为从最佳实践的角度来看,您不应将业务对象的结构公开为数据契约,而是定义"数据契约特定"类并将业务转换为契约.它可能需要额外的工作,但从关注点的分离和保护与变化的角度来看,额外的工作可能是值得的.
在微软模式与实践"服务工厂建模版"实现了这一点,并且还提供了工具来自动生成业务<=>合同转换器类-这是一个很好的VS插件,并且也代表了WCF微软的最佳实践.