如何从特定 OU 的用户列表中获取组的特定部分并将其放入表中?

问题描述

正如标题所说,我需要获取用户组的组名的特定部分。 是的,Get-ADPrincipalGroupMembership 允许获取用户组。但它返回所有用户的组(虽然我想得到一个确切的组),据我所知,只返回一个确切的用户

所以我有三个 OU。每个 OU 都有用户。每个用户都是几个组的成员,但我需要为每个用户获取一个具有标准名称的组。标准名称department - X,其中 X 部分特定于每个用户。因此,在结果中,我想要一个表格,其中包含 NameSamAccountNameX 部分的组。 >

因此,我需要:

  1. 从确切的 OU 获取用户及其组列表;
  2. 从所有用户及其组的列表中,我需要获取每个用户具有标准名称的组。标准名称department - X,其中X部分是针对每个用户的,一个用户可以有多个具有标准名称的组;
  3. 对于每个用户,我需要从具有标准名称的组中获取 X 部分。

解决方法

我会尝试这样的事情:

-

这会获取给定 OU 中的所有用户及其成员资格。 memberOf 属性的值是作为字符串的组的 DN,因此类似于 Get-ADUser -filter * -SearchBase "OU=OU1,OU=OU2,OU=OU3,DC=domain,DC=local" -Properties memberOf | % { [PSCustomObject]@{ Name = $_.Name; SamAccountName = $_.SamAccountName; Groups = ($_.MemberOf | ? { $_ -match "department" } | % { $_.Split(',')[0].Split('=')[1].Replace("department - ","") }) -join "," } } 。其中,它只选择与 department 匹配的条目,并用逗号和等号分割 DN 以获得 CN 部分(应与组名称匹配)。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...