CRM从2013开始引入了entityimage的概念,具体这个字段怎么设置的,图像是怎么上传的这里就不谈了。说实在的这玩意在项目中没啥用,所以也没去关注,直到最近遇到了个难题,要在外部系统去获取这个头像才来研究下。
msdn中的这篇:https://msdn.microsoft.com/en-us/library/dn511697.aspx,讲述了如何去设置和查询头像,当然我只关心retrieve,所以看到了这段,我表示我被深深的坑到了。
下图是我取的systemuser中的一条记录,就没查到entityimage这个字段,只有与之先关的3个字段
分别对应下面3个value值,最后一个是图片的相对路径,当我很happy的拿这个地址去浏览器里访问的时候,想必你也已经料到了,是要身份验证的,所以对于第三方系统而言根本没用
最后只能去数据库中看看这玩意在里面到底存的是啥,看到这个应该都懂了
这里附上demo的代码
string sql = @"SELECT entityimage FROM systemuser where systemuserid='B3EB9804-6CD8-E511-9413-D04319595BED'"; SqlConnection con = new SqlConnection("data source=;database=Origin_MSCRM;uid=sa;pwd="); SqlDataAdapter ad = new SqlDataAdapter(sql, con); DataSet ds = new DataSet(); ad.Fill(ds); byte[] imageBytes = ds.Tables[0].Rows[0]["entityimage"] as byte[]; var fs = new BinaryWriter(new FileStream(@"d:123.jpg", FileMode.Append, FileAccess.Write)); fs.Write(imageBytes);上面的代码取出的只是数据流,那最上面通过组织服务取出的那3个字段是啥呢,请看下图,关联的是一张叫imagedescriptor的表,对应的字段意思一目了然