伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

将Dynamics 365中的用户及其角色、角色导出到Excel中

来源:本站原创 浏览:89次 时间:2022-06-08

关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复240或者20161204可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong.me 。

为了便利于用户及用户权限审计,需要将系统的用户及其角色、角色、角色权限等导出到Excel方便查看。我这里就以这样一个需求为例来做一个简单的控制台应用程序来导出这些信息到Excel中。为了方便查看结果,我这里除了系统管理员,还建立几个用户,团队来展示效果。

这里说一下如何为Dynamics 365建立CRM用户。我们On-Premise的Dynamics CRM一般(注意是一般,因为你如果了SSO的话,用户信息也可以不存储在CRM服务器所在AD中)需要先在CRM服务器所在的AD中增加用户。而Dynamics 365则是需要先在 Office 365 门户的用户管理部分 增加用户。打开的界面如下,点击 管理员 这个磁贴。

 

点击 添加用户 链接添加一个用户,我这里自己创建密码,不使用生成的随机密码。注意产品许可证要包括Dynamics 365的许可证,我这里是 Dynamics 365 Plan 1 Enterprise Edition。

 

然后我们就可以去Dynamics 365中的 设置 > 安全性 >用户就可以看到这个新建的用户了。

然后就是设置业务部门,安全角色等,这里和On-Premise版本的Dynamics CRM一样,就不赘述了。

下面就是我们的程序了,我创建一个控制台应用程序,除了要添加对Dynamics 365相关DLL的引用外,还需要添加对Microsoft.Office.Interop.Excel的引用,添加引用的时候选择 COM, 然后搜索excel就可以找到。运行后面的程序还需要本机安装了Excel。

 

Dynamics 365中的 安全角色 没有导出功能,包括使用高级查找也是如此,所以我们只有写程序导出了。

 

所有使用的程序代码如下:

using Microsoft.Office.Interop.Excel;using Microsoft.Xrm.Sdk;using Microsoft.Xrm.Sdk.Client;using Microsoft.Xrm.Sdk.Messages;using Microsoft.Xrm.Sdk.Metadata;using Microsoft.Xrm.Sdk.Query;using Microsoft.Xrm.Tooling.Connector;using System;using System.Collections.Generic;using System.Configuration;using System.Drawing;using System.IO;using System.Linq;using System.ServiceModel;using System.ServiceModel.Description;using System.Text;using System.Xml;namespace LuoYongLab{    class Program    {        static void Main(string[] args)        {            try            {                var crmSvc = new CrmServiceClient(ConfigurationManager.ConnectionStrings["CRM365"].ConnectionString);                if (crmSvc.IsReady)                {                    Console.WriteLine("导出安全角色开始");                    var fetchXml = string.Format(@"<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='false'><entity name='role'><attribute name='name' /><attribute name='businessunitid' /><attribute name='roleid' /><order attribute='name' descending='false' /><filter type='and'><condition attribute='parentroleid' operator='null' /></filter></entity></fetch>");                    EntityCollection ecRoles = crmSvc.RetrieveMultiple(new FetchExpression(fetchXml));                    var excelApp = new Application();                    excelApp.Visible = false;                    Workbook securityWorkbook = excelApp.Workbooks.Add();                    Worksheet rolesWorksheet = (Worksheet)excelApp.ActiveSheet;                    rolesWorksheet.Name = "安全角色";                    int row = 1;                    rolesWorksheet.Cells[1, 1] = "角色名称";                    rolesWorksheet.Cells[1, 2] = "业务部门";                    rolesWorksheet.Cells[1, 3] = "角色ID";                    //rolesWorksheet.Rows[1].Font.Bold = true;//字体加粗                    row++;                    foreach (var roleEntity in ecRoles.Entities)                    {                        rolesWorksheet.Cells[row, 1] = roleEntity.GetAttributeValue<string>("name");                        rolesWorksheet.Cells[row, 2] = roleEntity.GetAttributeValue<EntityReference>("businessunitid").Name;                        rolesWorksheet.Cells[row, 3] = roleEntity.GetAttributeValue<Guid>("roleid").ToString();                        row++;                    }                    //rolesWorksheet.Columns[1].AutoFit();//自动列宽                    rolesWorksheet.Range["A1", "C" + (row - 1)].AutoFormat(XlRangeAutoFormat.xlRangeAutoFormatColor1);                    Console.WriteLine("导出用户及其安全角色开始");                    fetchXml = @"<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='false'><entity name='systemuser'><attribute name='fullname' /><attribute name='businessunitid' /><attribute name='systemuserid' /><attribute name='domainname' /><order attribute='fullname' descending='false' /><filter type='and'><condition attribute='isdisabled' operator='eq' value='0' /><condition attribute='accessmode' operator='ne' value='3' /></filter></entity></fetch>";                    EntityCollection ecUsers = crmSvc.RetrieveMultiple(new FetchExpression(fetchXml));                    Worksheet usersWorksheet = securityWorkbook.Worksheets.Add();                    usersWorksheet.Name = "用户";                    row = 1;                    usersWorksheet.Cells[1, 1] = "用户姓名";                    usersWorksheet.Cells[1, 2] = "业务部门";                    usersWorksheet.Cells[1, 3] = "用户账户";                    usersWorksheet.Cells[1, 4] = "用户角色";                    usersWorksheet.Cells[1, 5] = "用户ID";                    row++;                    foreach (var userEntity in ecUsers.Entities)                    {                        usersWorksheet.Cells[row, 1] = userEntity.GetAttributeValue<string>("fullname");                        usersWorksheet.Cells[row, 2] = userEntity.GetAttributeValue<EntityReference>("businessunitid").Name;                        usersWorksheet.Cells[row, 3] = userEntity.GetAttributeValue<string>("domainname");                        usersWorksheet.Cells[row, 4] = string.Join(",", GetUserRoles(crmSvc.OrganizationServiceProxy, userEntity.GetAttributeValue<Guid>("systemuserid")).Distinct());                        usersWorksheet.Cells[row, 5] = userEntity.GetAttributeValue<Guid>("systemuserid").ToString();                        row++;                    }                    usersWorksheet.Range["A1", "E" + (row - 1)].AutoFormat(XlRangeAutoFormat.xlRangeAutoFormatColor1);                    securityWorkbook.SaveAs(Filename: "CRMSecurities.xlsx", FileFormat: XlFileFormat.xlWorkbookDefault);                    securityWorkbook.Close();                    excelApp.Quit();                }                else                {                    Console.WriteLine("连接CRM出错:" + crmSvc.LastCrmError);                }                Console.WriteLine("程序运行完成!");                Console.ReadKey();            }            catch (FaultException ex)            {                Console.WriteLine("程序出现异常:ex.Message=" + ex.Message);                Console.ReadKey();            }        }        static IEnumerable<string> GetUserRoles(IOrganizationService service, Guid userId)        {            //首先获取用户直接授予的角色            string fetchXml = string.Format(@"<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='true' no-lock='true'><entity name='role'><attribute name='name' /><link-entity name='systemuserroles' from='roleid' to='roleid' visible='false' intersect='true'><link-entity name='systemuser' from='systemuserid' to='systemuserid' alias='ad'><filter type='and'><condition attribute='systemuserid' operator='eq' value='{0}' /></filter></link-entity></link-entity></entity></fetch>", userId);            var userRolesDirect = service.RetrieveMultiple(new FetchExpression(fetchXml)).Entities.Select(x => x.GetAttributeValue<string>("name"));            //找出用户加入的所有负责人团队            fetchXml = string.Format(@"<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='true'><entity name='team'><attribute name='teamid' /><filter type='and'><condition attribute='teamtype' operator='eq' value='0' /></filter><link-entity name='teammembership' from='teamid' to='teamid' visible='false' intersect='true'><link-entity name='systemuser' from='systemuserid' to='systemuserid' alias='ah'><filter type='and'><condition attribute='systemuserid' operator='eq' value='{0}' /></filter></link-entity></link-entity></entity></fetch>", userId);            var userTeams = service.RetrieveMultiple(new FetchExpression(fetchXml)).Entities.Select(x => x.GetAttributeValue<Guid>("teamid"));            //团队拥有的角色也是这个团队所有用户拥有的角色,所以还要加上这部分角色            var fetchXmlSb = new StringBuilder("<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='true'>");            fetchXmlSb.Append("<entity name='role'>");            fetchXmlSb.Append("<attribute name='name' />");            fetchXmlSb.Append("<order attribute='name' descending='false' />");            fetchXmlSb.Append("<link-entity name='teamroles' from='roleid' to='roleid' visible='false' intersect='true'>");            fetchXmlSb.Append("<link-entity name='team' from='teamid' to='teamid' alias='ak'>");            fetchXmlSb.Append("<filter type='or'>");            foreach (var team in userTeams)            {                fetchXmlSb.Append(string.Format("<condition attribute='teamid' operator='eq' value='{0}' />", team));            }            fetchXmlSb.Append("</filter>");            fetchXmlSb.Append("</link-entity>");            fetchXmlSb.Append("</link-entity>");            fetchXmlSb.Append("</entity>");            fetchXmlSb.Append("</fetch>");            var userRolesInTeam = service.RetrieveMultiple(new FetchExpression(fetchXmlSb.ToString())).Entities.Select(x => x.GetAttributeValue<string>("name"));            return userRolesDirect.Concat(userRolesInTeam);        }    }}

 

得到的结果如下,这个Excel有两个Sheet,我分别截图,我的测试结果是把用户直接授予的角色和用户加入团队获取的角色都拿到了。

 

 


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net