需要列表中的每个名称才能查询活动目录



为什么它只显示最后一个对象,而不是每个循环的所有对象?

$str = @"
First1 Last1
First2 Last2
First3 Last3
First4 Last4
"@
foreach ($line in $str.Split("`n")) {
$userOBJ = Get-ADUser -Filter {Name -like $line} 
$userOBJ
}

"输出"只有一条记录。

DistinguishedName : CN=First Last,OU=BLAH and BLAH,OU=BLAH BLAH,DC=corp,DC=domain,DC=com
Enabled           : True
GivenName         : First
Name              : First Last
ObjectClass       : user
ObjectGUID        : XXXXXX-XXXXXXXXX
SamAccountName    : useranme
SID               : XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Surname           : Last
UserPrincipalName : username@comain.com

试试这个:

$str = @"
First1 Last1
First2 Last2
First3 Last3
First4 Last4
"@
#Split your string and remove empty/null values.
$Names = $str.Split("`r`n") | ? { $_ }
#Make one filter request with all your names.
$Filter = "Name -like '$($Names -Join "' -or Name -like '")'"
Get-ADUser -Filter $Filter

向具有多个筛选器的 AD 发出一个请求将提高域控制器的速度并减少开销。

说明如何创建过滤器

当想要构建包含多个搜索结果的长筛选器时,需要按以下方式设置筛选器的格式:

$Filter = "Name -Like 'First1 Last1' -or Name -Like 'First2 Last2' -or Name 'First3 Last3' -or Name -Like 'First4 Last4'"

最简单的方法是执行连接,使用数组中每个值之间的任何内容。在本例中,' -or Name -Like '位于$Names中的每个值之间。

$JoinResult = $Names -Join "' -or Name -Like '"

$JoinResult -eq :

First1 Last1' -or Name -Like 'First2 Last2' -or Name 'First3 Last3' -or Name -Like 'First4 Last4

下一步是封顶它。(该筛选器字符串的开始和结束)您希望筛选器以Name -Like '开头,以尾随'结束

$Filter = "Name -Like '$JoinResult'"

在一行中完成所有这些是:

$Filter = "Name -like '$($Names -Join "' -or Name -like '")'"
foreach ($line in $str -Split('rn')) {
Get-ADUser -Filter {Name -eq $line} 
}

添加 -Split 和 \r 解决了我的问题。谢谢@gbabu和@Bacon Bits带领我朝着正确的方向前进。

最新更新