sar*_* ks 5 c# powershell azure office365 azure-active-directory
我可以使用 C# 中的 Powershell cmdlet 从 O365 获取用户详细信息。问题是获取时间。那太慢了。
每个用户需要 2 秒,所以如果我有大量用户,这将导致时间问题。
在这里,我只想打印所有用户的信息,如姓名、组详细信息、许可证。我怎样才能更快地做到这一点?
试过一个:
Runspace runspace = RunspaceFactory.CreateRunspace();
runspace.Open();
Pipeline UserDetailsPipe = runspace.CreatePipeline();
UserDetailsPipe.Commands.AddScript("Get-AzureADUser");
foreach (PSObject info in UserDetailsPipe.Invoke()) /////////*******
{
ArrayList Groups = new ArrayList(); // to hold memberOf
ArrayList Licenses = new ArrayList(); // to hold of licenses
string UserPrincipalName = info.Members["UserPrincipalName"].Value.ToString();
string DisplayName = info.Members["DisplayName"].Value.ToString();
//Getting MemberOf
Pipeline memberPipe = runspace.CreatePipeline();
memberPipe.Commands.AddScript("Get-AzureADUser -ObjectId '" + UserPrincipalName + "'| Get-AzureADUserMembership");
//Getting Licenses
Pipeline licensePipe = runspace.CreatePipeline();
licensePipe.Commands.AddScript("$license = Get-AzureADUserLicenseDetail -ObjectId '" + UserPrincipalName + "' | select ServicePlans ");
licensePipe.Commands.AddScript("$license.ServicePlans");
foreach (var licensenames in licensePipe.Invoke())////////*****
{
Licenses.Add(licensenames.Members["ServicePlanName"].Value.ToString());
}
foreach (var memberOf in memberPipe.Invoke())////////*******
{
Groups.Add(memberOf.Members["DisplayName"].Value.ToString());
}
}
Run Code Online (Sandbox Code Playgroud)
我知道我正在调用许多管道。那么如何仅使用一次调用来获得我的答案呢?(它也可能在 PowerShell 类中)。
看来最好的解决方案是合并到尽可能少的脚本中,以减少管道的数量。我还建议使用该PowerShell对象而不是Runspaces
另外,为了Collection在调用后获得最终的所有结果,请使用该.AddStatement()方法。下面对此进行了演示。AddStatement 的文档
这需要根据您的环境进行修改,因为我只是两次获取日期以演示将两个日期返回到最终集合。
using (PowerShell powershell = PowerShell.Create()) {
powershell.AddScript("Get-Date");
powershell.AddStatement().AddScript("Get-Date");
Collection<PSObject> result = powershell.Invoke();
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
388 次 |
| 最近记录: |