博文作者:悦享人生@悦享人
除非注明,本文原创。转载请以链接形式注明本文地址,谢谢。
原文链接:http://yxzhao.com/2013/get-members-of-nested-group/

Exchange 通讯组可以嵌套多个通讯组,但是 Exchange Management Shell 无法直接获取嵌套组里的成员。不过没关系,我们可以通过简单的构建一个函数,通过 PowerShell 来执行。

将下面的代码保存为 .ps1 文件,如 Get-NestedGroup.ps1,然后在 EMS 里执行,后面跟一个参数,就是需要查询的邮件列表名或 Alias。结果将输出到一个 CSV 文件,文件名就是你输入的邮件列表名或 Alias。

 
 
   
  1. param ($group
  2. [array]$members = @() 
  3. function Get-DLMemberRecurse 
  4.     foreach ($varTemp in get-distributiongroupmember $args[0]) 
  5.     { 
  6.         $varTemp 
  7.         if ($varTemp.RecipientType -like "Mail*Group")  
  8.             {  
  9.                 $members += $varTemp 
  10.                 Get-DLMemberRecurse $varTemp.Identity 
  11.             } 
  12.     } 
  13.     $members = $members | Select -Unique 
  14.     return $members 
  15. ## 设置为全局查询,当有多个域时必须 
  16. Set-ADServerSettings -ViewEntireForest $true 
  17. if (!(get-group $group)) 
  18.     throw "Group not found" 
  19. [array]$members = Get-DLMemberRecurse $group 
  20. ## Select-Object 后面是输出 CSV 文件里的列,可以按需要增删 
  21. $members = $members | where-Object {($_.RecipientType -eq "UserMailbox") -Or ($_.RecipientType -eq "MailContact")} | Select -Unique | Select-Object Alias,DisplayName,PrimarySmtpAddress,UserPrincipalName | Export-csv -encoding utf8 -Path "D:\$group.csv" 
 

执行方式如下:

1
[PS] C:\Windows\system32>D:\Get-NestedGroup.ps1 MyGroup

注意:输出的 CSV 文件是默认在 D: 根目录,可以在最后一行代码里进行更改,这个目录必须要存在。