用户和本地组使用Powershell报告?

时间:2009-06-09 14:12:22

标签: windows security powershell

使用PowerShell是否有一种简单的方法来显示计算机上活动的所有本地Windows组以及属于这些组的用户?这个问题的第二部分是如果它可以扩展到一次查看多台机器。

4 个答案:

答案 0 :(得分:13)

实际上你可以使用ADSI类型的快捷方式和WinNT名字对象。这是一个列出自己机器中的组和成员的示例:

$server="."
$computer = [ADSI]"WinNT://$server,computer"

$computer.psbase.children | where { $_.psbase.schemaClassName -eq 'group' } | foreach {
    write-host $_.name
    write-host "------"
    $group =[ADSI]$_.psbase.Path
    $group.psbase.Invoke("Members") | foreach {$_.GetType().InvokeMember("Name", 'GetProperty', $null, $_, $null)}
    write-host
}

答案 1 :(得分:7)

Powershell对此类功能没有任何固有的支持。但是,使用几个powershell函数包装“net localgroup”命令很容易,因此可以在管道中启用它。

获取本地小组

function Get-LocalGroups() {
  net localgroup | ?{ $_ -match "^\*.*" } | %{ $_.SubString(1) };
}

获取本地小组成员

function Get-LocalGroupMembers() {
  param ([string]$groupName = $(throw "Need a name") )
  $lines = net localgroup $groupName
  $found = $false
  for ($i = 0; $i -lt $lines.Length; $i++ ) {
    if ( $found ) {
      if ( -not $lines[$i].StartsWith("The command completed")) {
        $lines[$i]
      }
    } elseif ( $lines[$i] -match "^----" ) {
      $found = $true;
    }
  }
}

答案 2 :(得分:1)

Jay Levy的回答变成了一个函数:)

Function Get-LocalGroupMembers
{
    Param(
        [string]
        $server = "."
    )
    Try
    {
        $computer = [ADSI]"WinNT://$( $Server ),computer"
        $computer.psbase.children | 
            where { 
                $_.psbase.schemaClassName -eq 'group' 
            } |
                ForEach {
                    $GroupName = $_.Name.ToString()
                    $group =[ADSI]$_.psbase.Path
                    $group.psbase.Invoke("Members") |
                        foreach {
                            $memberName = $_.GetType().InvokeMember("Name", 'GetProperty', $null, $_, $null) -replace "WinNT:", ""

                            $props = @{
                                "LocalGroup" = $GroupName
                                "MemberName" = $memberName
                            }

                            $obj = New-Object -TypeName psobject -Property $props
                            Write-Output $obj
                        } # foreach members
                } # foreach group
    }
    Catch
    {
        Throw
    }
}

获取本地小组成员

Get-LocalGroupMembers

获取另一台计算机的本地组成员

Get-LocalGroupMembers -Server $Computer

答案 3 :(得分:0)

以下是Shay Levy脚本的改进版本,该版本适用于本地群组,其中包括"孤儿"哪些SID无法解决的帐户。

$server = "$env:COMPUTERNAME"
$computer = [ADSI]"WinNT://$server,computer"

$computer.psbase.children | where { $_.psbase.schemaClassName -eq 'group' } | foreach {
    write-host $_.name
    write-host "------"
    $group =[ADSI]$_.psbase.Path
    $group.psbase.Invoke("Members") | foreach {$_."GetType".Invoke().InvokeMember("Name", 'GetProperty', $null, $_, $null)}
    write-host
}