最近在使用DDD重新搭建公司内部OA的架构,具体情况搭好了应该会写一下,这里说的是今天遇到的问题。

  先简单说一下相关的几个部分:

  1.聚合。聚合分成了两个模块:一个包含审批单据等估计至少今年不会怎么变的抽象模型;另外一个包含不同审批单据的实现类,继承至抽象的模块;由于主要是要说这一块,就贴一点部分代码上来,与本随笔要说的无关的部分就省略号了。。。

  [DomainAttribute(DomainType = ApplyDomainType.Root, Description = "申请单")]
public class RequisitionBase
{
internal int ID { get; set; }
internal string ProcesssCode { get; set; } /// <summary>
/// 流程类型,定义流程类型,例如“TB”,“HT”等
/// </summary>
internal string ProcessType { get; set; } /// <summary>
/// 申请人域帐号
/// </summary>
internal string ApplicantUserID { get; set; } /// <summary>
/// 申请人姓名
/// </summary>
internal string ApplicantUserName { get; set; } /// <summary>
/// 申请日期
/// </summary>
internal DateTime ApplicantDate { get; set; } //还有一些属性和方法,不过都不重要了
}
    public class AllographRequisition : RequisitionBase
{
public AllographRequisition()
{
//代签项目申请单实现类,略。。。
}
}

  2.用于UI和应用层之间传数据的DTO,命名应该用信息的,不过咱纯粹的不愿意用那个单词。。。

    public class AllographRequisitionData
{
//方便测试
public AllographRequisitionData(AllographRequisitionData data)
{
Project = data.Project;
RequisitionContent = data.RequisitionContent;
} public AllographRequisitionData(ProjectContentData project, AllographRequisitionContentData requisitionContent)
{
Project = project;
RequisitionContent = requisitionContent;
} public ProjectContentData Project { get; set; }
public AllographRequisitionContentData RequisitionContent { get; set; } public int ID { get; set; }
public string ProcesssCode { get; set; } /// <summary>
/// 流程类型,定义流程类型,例如“TB”,“HT”等
/// </summary>
public string ProcessType { get; set; } /// <summary>
/// 申请人域帐号
/// </summary>
public string ApplicantUserID { get; set; } /// <summary>
/// 申请人姓名
/// </summary>
public string ApplicantUserName { get; set; } /// <summary>
/// 申请日期
/// </summary>
public DateTime ApplicantDate { get; set; } //一些属性。。。
}

  3.应用服务,这随笔发生的地方,DTO与聚合映射的所在,只是个简单的意思,不要太在意

        public AllographRequisition DataToEntity(AllographRequisitionData data)
{
Mapper.CreateMap<AllographRequisitionData, AllographRequisition>(); AllographRequisition requisition
= Mapper.Map<AllographRequisitionData, AllographRequisition>(data);
DateTime date = requisition.ApplicantDate;
return requisition;
}

  4.单元测试,因为应用层咱是用TDD开始的。。。

        [TestMethod]
public void Save()
{
RequisitionService service = new RequisitionService();
AllographRequisitionData t = new AllographRequisitionData(service.GetTestData());
t.ApplicantDate = DateTime.Now;
var data = service.Save(t); Assert.IsInstanceOfType(data, typeof(AllographRequisition));
Assert.AreEqual(data.ApplicantDate, t.ApplicantDate);
}

  由于咱这的程序员节操无法保证,无奈之下,领域层中的聚合都被我用了internal的访问级别,保证即使他们引用了,也看的见摸不着,然后使用了友元的方式对特定的几个模块提供访问,抽象的模型所在模块的代码不对程序员公开,以此来保证封装好的逻辑不被胡乱引用而破坏。

[assembly: InternalsVisibleTo("ChanceVariation.Application.ApplicationService")]

  于是,拖了半天的剧情终于来到了正文部分,一般情况下用AutoMapper的时候都是映射public的属性,不过只要能访问的应该都是可以映射的,该怎么办呢,这几天google用域名访问不正常,懒得翻IP,只好先百度,不得不说百度对于中文分词是好些,可惜搜技术问题相当不给力,没发现一点有用的。于是只好去github上下AutoMapper的开源代码,由于我现在的系统只能装VS2012所以没办法连代码调试,只好一点点看,然后结合StackOverFlow上的一些讨论,终于找到了这个方法

        public IMappingExpression<TSource, TDestination> IgnoreAllPropertiesWithAnInaccessibleSetter()
{
var properties = typeof(TDestination).GetProperties().Where(HasAnInaccessibleSetter);
foreach (var property in properties)
ForMember(property.Name, opt => opt.Ignore());
return new MappingExpression<TSource, TDestination>(_typeMap, _serviceCtor, _configurationContainer);
}

此方法也可以解决private set不能映射的情况

internal DateTime ApplicantDate { get; private set; }

使用方法:

Mapper.CreateMap<AllographRequisitionData, AllographRequisition>()
.IgnoreAllPropertiesWithAnInaccessibleSetter()
.ForMember(dest => dest.ApplicantDate, opt => opt.MapFrom(source => source.ApplicantDate));

总算是映射成功了,不过终归是有些麻烦,暂时没时间管它了,这个月过去再琢磨有木有好办法。

AutoMapper对internal访问级别属性的映射的更多相关文章

  1. resultMap处理字段和属性的映射关系

    1.resultMap处理字段和属性的映射关系 若字段名和实体类中的属性名不一致,则可以通过resultMap设置自定义映射 <!-- resultMap:设置自定义映射 属性: id:表示自定 ...

  2. 001-List,数组,Set,Map属性的映射

    hibernate.cfg.xml: <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configur ...

  3. ASP.Net MVC 中EF实体的属性取消映射数据库、自定义名称

    例如:数据库中一个字段名称为CompanyId 自定义实体数据名称 [Column("CompanyId")] public int Id{ get; set; } 这样就可以使用 ...

  4. 关于ibatis的实体类部分属性无法映射

    今天在编码中不小心就遇到了一个ibatis初学者偶尔会遇到的问题. 先来看这张图中的DictionPo的部分属性赋值都为空.其实,数据库中是有数据的. 再来看看mapper的写法 上面那个对象查询语句 ...

  5. C#两个实体之间相同属性的映射

    public static R Mapping<R, T>(T model) { R result = Activator.CreateInstance<R>(); forea ...

  6. EF实体类指定部分属性不映射成数据库字段特性

    添加NotMapped 特性 /// <summary> /// 用户名 /// </summary> [NotMapped] public string user_name ...

  7. EF实体类指定部分属性不映射数据库标记

    命名空间 ;using System.ComponentModel.DataAnnotations.Schema; 实体部分 public partial class Student { [NotMa ...

  8. 使用AutoMapper进行对象间映射

    在开发过程中,难免遇到下面这种情况:两个(或多个)对象所拥有的大多数属性是重复的,我们需要在对象间进行映射(即将一个对象的属性值赋给另一个对象.通常我们可以进行如下操作: A a=new A(); a ...

  9. .NET的对象映射工具AutoMapper使用笔记

    AutoMapper是一个.NET的对象映射工具. 项目地址:https://github.com/AutoMapper/AutoMapper. 帮助文档:https://github.com/Aut ...

随机推荐

  1. C语言 · 薪水计算

    问题描述 编写一个程序,计算员工的周薪.薪水的计算是以小时为单位,如果在一周的时间内,员工工作的时间不超过40 个小时,那么他/她的总收入等于工作时间乘以每小时的薪水.如果员工工作的时间在40 到50 ...

  2. 利用CSS中的:after、: before制作的边三角提示框

    小颖昨天分享了一篇参考bootstrap中的popover.js的css画消息弹框今天给大家再分享一篇使用:before和:after伪元素画消息弹框的CSS. 画出来是介个酱紫的: 有没有觉得画的萌 ...

  3. [C#] 走进 LINQ 的世界

    走进 LINQ 的世界 序 在此之前曾发表过三篇关于 LINQ 的随笔: 进阶:<LINQ 标准查询操作概述>(强烈推荐) 技巧:<Linq To Objects - 如何操作字符串 ...

  4. await and async

    Most people have already heard about the new “async” and “await” functionality coming in Visual Stud ...

  5. java面向对象中的关键字

    1,super关键字 super:父类的意思 1. super.属性名 (调用父类的属性) 2. super.方法名 (调用父类的方法) 3. super([参数列表])(调用父类的构造方法) 注意: ...

  6. JavaScript将字符串中的每一个单词的第一个字母变为大写其余均为小写

    要求: 确保字符串的每个单词首字母都大写,其余部分小写. 这里我自己写了两种方法,或者说是一种方法,另一个是该方法的变种. 第一种: function titleCase(str) { var new ...

  7. 说说BPM数据表和日志表中几个状态字段的详细解释

    有个客户说需要根据这些字段的值作为判断条件做一些定制化需求,所以需要知道这些字段的名词解释,以及里面存储的值具体代表什么意思 我只好为你们整理奉上这些了! Open Work Sheet  0 Sav ...

  8. (一)Spark简介-Java&Python版Spark

    Spark简介 视频教程: 1.优酷 2.YouTube 简介: Spark是加州大学伯克利分校AMP实验室,开发的通用内存并行计算框架.Spark在2013年6月进入Apache成为孵化项目,8个月 ...

  9. [故障公告]受阿里云部分ECS服务器故障影响,目前无法上传图片与文件

    抱歉!今天下午阿里云华东1可用区B的部分ECS服务器出现IO HANG问题,受此影响,我们的图片与文件上传服务器无法访问,由此给您带来麻烦,请您谅解. 16:30左右开始,我们发现图片与文件上传服务器 ...

  10. SQL SERVER全面优化-------Expert for SQL Server 诊断系列

    现在很多用户被数据库的慢的问题所困扰,又苦于花钱请一个专业的DBA成本太高.软件维护人员对数据库的了解又不是那么深入,所以导致问题迟迟不能解决,或只能暂时解决不能得到根治.开发人员解决数据问题基本又是 ...