Exchange 通讯组可以嵌套多个通讯组,但是 Exchange Management Shell 无法直接获取嵌套组里的成员。不过没关系,我们可以通过简单的构建一个函数,通过 PowerShell 来执行。 将下面的代码保存为 .ps1 文件,如 Get-NestedGroup.ps1,然后在 EMS 里执行,后面跟一个参数,就是需要查询的邮件列表名或 Alias。结果将输出到一个 CSV 文件,文件名就是你输入的邮件列表名或 Alias。
[Shell] 纯文本查看 复制代码 param ($group)
[array]$members = @()
function Get-DLMemberRecurse
{
foreach ($varTemp in get-distributiongroupmember $args[0])
{
$varTemp
if ($varTemp.RecipientType -like "Mail*Group")
{
$members += $varTemp
Get-DLMemberRecurse $varTemp.Identity
}
}
$members = $members | Select -Unique
return $members
}
## 设置为全局查询,当有多个域时必须
Set-ADServerSettings -ViewEntireForest $true
if (!(get-group $group))
{
throw "Group not found"
}
[array]$members = Get-DLMemberRecurse $group
## Select-Object 后面是输出 CSV 文件里的列,可以按需要增删
$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"
执行方式如下: | [backcolor=white !important] C:\Windows\system32>D:\Get-NestedGroup.ps1 MyGroup
|
注意:输出的 CSV 文件是默认在 D: 根目录,可以在最后一行代码里进行更改,这个目录必须要存在。
|