博文作者:悦享人生@悦享人
除非注明,本文原创。转载请以链接形式注明本文地址,谢谢。
原文链接:http://yxzhao.com/2013/get-members-of-nested-group/
Exchange 通讯组可以嵌套多个通讯组,但是 Exchange Management Shell 无法直接获取嵌套组里的成员。不过没关系,我们可以通过简单的构建一个函数,通过 PowerShell 来执行。
将下面的代码保存为 .ps1 文件,如 Get-NestedGroup.ps1,然后在 EMS 里执行,后面跟一个参数,就是需要查询的邮件列表名或 Alias。结果将输出到一个 CSV 文件,文件名就是你输入的邮件列表名或 Alias。
- 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"
执行方式如下:
1
|
[PS] C:\Windows\system32>D:\Get-NestedGroup.ps1 MyGroup
|
注意:输出的 CSV 文件是默认在 D: 根目录,可以在最后一行代码里进行更改,这个目录必须要存在。
转载于:https://blog.51cto.com/yxzhaocom/1171712