AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 120229
Accepted
Rihan Meij
Rihan Meij
Asked: 2010-03-08 20:44:40 +0800 CST2010-03-08 20:44:40 +0800 CST 2010-03-08 20:44:40 +0800 CST

使用 powershell 将用户添加到本地管理员组

  • 772

我想使用 PowerShell 将特定用户添加到机器上的本地管理员组。我将在本地计算机上具有管理权限的用户的上下文中运行 PowerShell 脚本。

windows powershell automation
  • 6 6 个回答
  • 93884 Views

6 个回答

  • Voted
  1. Peter Hahndorf
    2016-07-09T02:29:32+08:002016-07-09T02:29:32+08:00

    在 Server 2016 和 Windows 10 版本 1607 及更高版本上,您可以使用新的 PowerShell 本地用户 cmdlet:

    Add-LocalGroupMember -Group Administrators -Member username
    

    这是在 Windows Management Framework (WMF) 5.1 中添加的。

    Microsoft.PowerShell.LocalAccounts如果您只是将文件复制到某个$env:PsModulePath位置,该模块在 2012 R2 上运行良好。

    • 31
  2. Jim B
    2010-03-09T09:44:47+08:002010-03-09T09:44:47+08:00

    这是一个执行此功能的简单 2 行脚本

    $group = [ADSI]("WinNT://"+$env:COMPUTERNAME+"/administrators,group")
    $group.add("WinNT://$env:USERDOMAIN/usernameiwantoadd,user")
    

    有关详细信息,请参阅嘿,脚本专家!如何使用 Windows PowerShell 将域用户添加到本地组?

    所以有几个注释。在第一行中,我使用了字符串连接,我不必这样做(见下一行),但我喜欢这样做,因为它有助于突出我正在使用的变量。其次,这些行将添加一个域用户,如果你想添加一个本地用户只需删除$env:USERDOMAIN/

    • 16
  3. Best Answer
    user46713
    2010-04-15T08:36:33+08:002010-04-15T08:36:33+08:00

    这是我用来在多台计算机上使用 Powershell 将用户添加到本地管理员组的高级功能。

    用法:获取内容 C:\Computers.txt | 设置-LocalAdminGroupMembership -Account 'YourAccount'


    Function Global:Set-LocalAdminGroupMembership
    {
    
    
        <#
        .Synopsis
    
        .Description
    
        .Parameter $ComputerName,
    
        .Example
         PS> Set-LocalAdminGroupMembership -ComputerName $ComputerName -Account 'YourAccount'
    
        .Link
         about_functions
         about_functions_advanced
         about_functions_advanced_methods
         about_functions_advanced_parameters
    
        .Notes
         NAME:      Set-LocalAdminGroupMembership
         AUTHOR:    Innotask.com\dmiller
         LASTEDIT:  2/4/2010 2:30:05 PM
         #Requires -Version 2.0
        #>
    
    
    
        [CmdletBinding()]
        param(
        [Parameter(Position=0, ValueFromPipeline=$true)]
        $ComputerName = '.',
        [Parameter(Position=1, Mandatory=$true)]
        $Account
        )
    
    
        Process
        {  
    
            if($ComputerName -eq '.'){$ComputerName = (get-WmiObject win32_computersystem).Name}    
            $ComputerName = $ComputerName.ToUpper()
    
    
            $Domain = $env:USERDNSDOMAIN
    
            if($Domain){
                $adsi = [ADSI]"WinNT://$ComputerName/administrators,group"
                $adsi.add("WinNT://$Domain/$Account,group")
                }else{
                Write-Host "Not connected to a domain." -foregroundcolor "red"
                }
    
    
        }# Process
    
    
    }# Set-LocalAdminGroupMembership
    
    • 6
  4. Mohamed Jawad
    2021-01-19T00:44:59+08:002021-01-19T00:44:59+08:00

    将域用户添加到管理员组的简单步骤:

    Add-LocalGroupMember -Group Administrators -Member $env:USERDOMAIN\<username>
    

    注意:确保以“管理员身份”运行 PowerShell。

    • 3
  5. Daniel Engberg
    2013-09-21T04:35:48+08:002013-09-21T04:35:48+08:00

    这是另一种方法。这需要在管理员上下文中运行:

    $域=""
    $计算机名= "$env:计算机名"
    $group=$computer.psbase.children.find("管理员")
    
    函数 AddToGroup($number)
    {
         $group.add("WinNT://"+$domain+"/"+$number )
    }
    
    #将这些域用户/组加入本地管理员组
     添加到组“”
     添加到组“”
    
    #将这些域计算机账号加入本地管理员组。
    #计算机帐户总是以 $ 结尾。
    添加组“$”
    

    更多信息在我的网站上。

    • 0
  6. Emil
    2019-11-22T08:50:47+08:002019-11-22T08:50:47+08:00

    添加目标安全组中已存在的帐户会引发错误,因此您需要检查是否已添加帐户,但我的要求是向后兼容到 PowerShell v2.0

    下面是我用于将用户添加到本地管理员组的代码片段,该组在 2016 年之前适用于旧版本的 PowerShell for Windows Servers。代码示例将用于自定义 IIS AppPool 身份的服务帐户添加到本地管理员组。

    $appPoolIdentity = "DOMAIN\svc-acc-name"
    # check if user is already member of the local administrators group - using case insensitive string comparison
    if(((invoke-command {net localgroup administrators}) -match ($appPoolIdentity -replace '\\','\\')).Count -eq 0){
        Write-Host "The app pool identity user '$appPoolIdentity' is not found in the local 'Administrators' group."
        # add user to the local administrators group
        $adminGroup = [ADSI]("WinNT://$env:COMPUTERNAME/administrators,group")
        $adminGroup.Add("WinNT://$appPoolIdentity,user")
        Write-Warning "Added '$appPoolIdentity' to the local 'Administrators' group."
    }else{
        Write-Host "The app pool identity user '$appPoolIdentity' is already member of local 'Administrators' group."
    }
    

    在上面的 if 语句中使用的功劳net localgroup administrators转到这篇博文。

    • 0

相关问题

  • Vanilla Powershell 是否足以成为 Windows 和 DB 服务器管理员的语言?

  • 为什么添加新驱动器后我的磁盘驱动器访问速度如此之慢?

  • 在 Windows Server 2003 下使用 wscipt 从 .asp 文件运行 .exe

  • 最佳混合环境(OS X + Windows)备份?[关闭]

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve