Cómo utilizar PowerShell para encontrar administradores locales

En la era digital actual, la administración de sistemas y la gestión de la seguridad requieren a menudo el uso de scripts. Un aspecto vital para mantener la seguridad del sistema es realizar un seguimiento de los administradores locales en equipos Windows. El uso de PowerShell para obtener estos datos puede cambiar las reglas del juego para muchos profesionales de TI. Lee este artículo para averiguar cómo utilizar PowerShell para encontrar administradores locales. 

Antecedentes

PowerShell ha evolucionado hasta convertirse en un robusto lenguaje de scripting y shell. Especialmente para los profesionales de TI y los proveedores de servicios gestionados (MSP), los scripts como el proporcionado se vuelven indispensables. Los MSP suelen gestionar entornos de múltiples clientes, lo que dificulta la supervisión manual de cada detalle. Con los scripts para obtener información, como la lista de administradores locales, los MSP pueden garantizar que sólo las personas autorizadas tengan acceso elevado, protegiéndose contra posibles amenazas y actividades maliciosas.

El script para encontrar administradores locales

<#
.SYNOPSIS
    Updates a custom field with a list of local admins.
.DESCRIPTION
    Updates a custom field with a list of local admins.
.EXAMPLE
    No parameter needed
    
    Local Admins Found: Administrator, kbohlander, TESTDomain Admins
    Attempting to set Custom Field: LocalAdmins

PARAMETER: -CustomField "ReplaceWithAnyTextCustomField"    
    Updates the custom field you specified (defaults to "LocalAdmins"). The Custom Field needs to be writable by scripts (otherwise the script will report it as not found).

PARAMETER: -Delimiter "ReplaceWithYourDesiredDelimiter"
    Places whatever is entered encased of quotes between each user name. See below example.
.EXAMPLE
    -Delimiter " - "
    
    Local Admins Found: Administrator - kbohlander - TESTDomain Admins
    Attempting to set Custom Field: LocalAdmins
.OUTPUTS
    None
.NOTES
    Minimum OS Architecture Supported: Windows 7, Windows Server 2008
    Release Notes:
    Switched to using net localgroup as it's the most reliable. Removed PowerShell 5.1 requirement.
By using this script, you indicate your acceptance of the following legal terms as well as our Terms of Use at https://www.ninjaone.com/terms-of-use.
    Ownership Rights: NinjaOne owns and will continue to own all right, title, and interest in and to the script (including the copyright). NinjaOne is giving you a limited license to use the script in accordance with these legal terms. 
    Use Limitation: You may only use the script for your legitimate personal or internal business purposes, and you may not share the script with another party. 
    Republication Prohibition: Under no circumstances are you permitted to re-publish the script in any script library or website belonging to or under the control of any other software provider. 
    Warranty Disclaimer: The script is provided “as is” and “as available”, without warranty of any kind. NinjaOne makes no promise or guarantee that the script will be free from defects or that it will meet your specific needs or expectations. 
    Assumption of Risk: Your use of the script is at your own risk. You acknowledge that there are certain inherent risks in using the script, and you understand and assume each of those risks. 
    Waiver and Release: You will not hold NinjaOne responsible for any adverse or unintended consequences resulting from your use of the script, and you waive any legal or equitable rights or remedies you may have against NinjaOne relating to your use of the script. 
    EULA: If you are a NinjaOne customer, your use of the script is subject to the End User License Agreement applicable to you (EULA).
#>

[CmdletBinding()]
param (
    [Parameter()]
    [String]$CustomField = "LocalAdmins",
    [Parameter()]
    [String]$Delimiter = ', '
)

begin {
    if ($env:customFieldName -and $env:customFieldName -notlike "null") { $CustomField = $env:customFieldName }
    if ($env:delimiter -and $env:delimiter -notlike "null") { $Delimiter = $env:delimiter }
    $CheckNinjaCommand = "Ninja-Property-Set"
}
process {
    # Get objects in the Administrators group, includes user objects and groups
    $Users = net.exe localgroup "Administrators" | Where-Object { $_ -AND $_ -notmatch "command completed successfully" } | Select-Object -Skip 4

    if (-not $Users) {
        Write-Error "[Error] No user's found! This is extremely unlikely is something blocking access to 'net localgroup administrators'?"
        exit 1
    }

    Write-Host "Local Admins Found (Users & Groups): $($Users -join $Delimiter)"
    if ($(Get-Command $CheckNinjaCommand -ErrorAction SilentlyContinue).Name -like $CheckNinjaCommand -and -not [string]::IsNullOrEmpty($CustomField) -and -not [string]::IsNullOrWhiteSpace($CustomField)) {
        Write-Host "Attempting to set Custom Field: $CustomField"
        Ninja-Property-Set -Name $CustomField -Value $($Users -join $Delimiter)
    }
    else {
        Write-Warning "Unable to set customfield either due to legacy OS or this script is not running as an elevated user."
    }
}
end {
    
    
    
}

 

Accede a más de 300 scripts en el Dojo de NinjaOne

Obtén acceso

Análisis detallado

El script para encontrar administradores locales se inicia estableciendo los parámetros por defecto, en particular un campo personalizado llamado «LocalAdmins» y utilizando una coma como delimitador por defecto. Así es como funciona:

  • Inicialización: el script comienza configurando los comandos necesarios, «Get-LocalGroupMember» para obtener los miembros del grupo local y «Ninja-Property-Set» para configurar las propiedades en NinjaOne, una conocida plataforma de gestión de TI.
  • Recuperación de los administradores: en el bloque de proceso, el script comprueba si el comando «Get-LocalGroupMember» está disponible. Si es así, lo utiliza para buscar administradores locales. Si no, utiliza por defecto el comando net.exe.
  • Formateo del output: tras recuperar la lista de administradores, formatea los nombres de usuario separándolos de cualquier nombre de dominio o máquina.
  • Integración con NinjaOne: por último, el script comprueba si el comando «Ninja-Property-Set» está disponible y luego actualiza el campo personalizado en NinjaOne con la lista de administradores locales.

Posibles casos de uso

Imagínate que eres administrador de TI de una empresa mediana con una plantilla remota en expansión. Dado que los empleados se conectan desde distintos lugares y dispositivos, resulta crucial garantizar que sólo el personal autorizado tenga acceso administrativo. Al desplegar este script para encontrar administradores locales, un profesional de TI puede obtener la lista de todos los administradores locales en varias estaciones de trabajo, lo que le permite auditar el acceso y tomar medidas correctivas si es necesario.

Comparaciones

Aunque existen varias formas de recuperar una lista de administradores locales, como mediante interfaces gráficas de usuario o herramientas de terceros, los scripts de PowerShell ofrecen automatización, escalabilidad y fácil integración. Por ejemplo, mientras que la interfaz gráfica de usuario nativa «Gestión de equipos» permite comprobar los administradores locales en una única estación de trabajo, nuestro script para encontrar administradores locales puede ampliarse a varios equipos, lo que proporciona una forma más eficaz de obtener estos datos, especialmente para los MSP que gestionan numerosos entornos de clientes.

FAQ

  • ¿Este script para encontrar administradores locales es exclusivo de Windows?
    Sí, está dirigido a equipos Windows, con soporte a partir de Windows 10 y Windows Server 2016.
  • ¿Puedo cambiar el delimitador?
    Sí, el delimitador se puede personalizar mediante el parámetro -Delimiter.
  • ¿Siempre necesito NinjaOne para usar este script?
    No, el script comprueba la disponibilidad del comando NinjaOne. Si no está disponible, sólo mostrará la lista y no intentará una actualización en NinjaOne.

Implicaciones

Saber quién tiene privilegios administrativos es crucial para la seguridad informática. Los administradores no autorizados o rogue pueden realizar cambios en el sistema, instalar software malicioso o acceder a información confidencial. Al supervisar y auditar periódicamente a los administradores locales, las organizaciones pueden mitigar significativamente los posibles riesgos de seguridad.

Recomendaciones

  • Realiza auditorías de forma periódica: ejecuta este script periódicamente para mantener una lista actualizada de los administradores locales.
  • Integra el script con una solución de supervisión: integra el output con soluciones de supervisión para recibir alertas sobre cambios en la lista de administradores locales.
  • Documentación: conserva la documentación de todos los usuarios a los que se hayan concedido derechos administrativos locales, asegurándote de que existe una razón empresarial válida para cada asignación.

Reflexiones finales

Mientras que los scripts PowerShell como el que hemos visto para encontrar administradores locales facilitan enormemente el proceso de obtención y gestión de administradores locales, plataformas como NinjaOne elevan estas funcionalidades. La capacidad de integración perfecta de NinjaOne, junto con sus sólidas herramientas de gestión de TI, garantiza que los administradores de sistemas tengan siempre el control, puedan responder rápidamente a los cambios y garanticen la seguridad y el rendimiento óptimos del sistema.

Próximos pasos

La creación de un equipo de TI próspero y eficaz requiere contar con una solución centralizada que se convierta en tu principal herramienta de prestación de servicios. NinjaOne permite a los equipos de TI supervisar, gestionar, proteger y dar soporte a todos sus dispositivos, estén donde estén, sin necesidad de complejas infraestructuras locales.

Obtén más información sobre NinjaOne Endpoint Management, echa un vistazo a un tour en vivoo tu prueba gratuita de la plataforma NinjaOne.

Categorías:

Quizá también te interese…

×

¡Vean a NinjaOne en acción!

Al enviar este formulario, acepto la política de privacidad de NinjaOne.

Términos y condiciones de NinjaOne

Al hacer clic en el botón «Acepto» que aparece a continuación, estás aceptando los siguientes términos legales, así como nuestras Condiciones de uso:

  • Derechos de propiedad: NinjaOne posee y seguirá poseyendo todos los derechos, títulos e intereses sobre el script (incluidos los derechos de autor). NinjaOne concede al usuario una licencia limitada para utilizar el script de acuerdo con estos términos legales.
  • Limitación de uso: solo podrás utilizar el script para tus legítimos fines personales o comerciales internos, y no podrás compartirlo con terceros.
  • Prohibición de republicación: bajo ninguna circunstancia está permitido volver a publicar el script en ninguna biblioteca de scripts que pertenezca o esté bajo el control de cualquier otro proveedor de software.
  • Exclusión de garantía: el script se proporciona «tal cual» y «según disponibilidad», sin garantía de ningún tipo. NinjaOne no promete ni garantiza que el script esté libre de defectos o que satisfaga las necesidades o expectativas específicas del usuario.
  • Asunción de riesgos: el uso que el usuario haga del script corre por su cuenta y riesgo. El usuario reconoce que existen ciertos riesgos inherentes al uso del script, y entiende y asume cada uno de esos riesgos.
  • Renuncia y exención: el usuario no hará responsable a NinjaOne de cualquier consecuencia adversa o no deseada que resulte del uso del script y renuncia a cualquier derecho o recurso legal o equitativo que pueda tener contra NinjaOne en relación con su uso del script.
  • CLUF: si el usuario es cliente de NinjaOne, su uso del script está sujeto al Contrato de Licencia para el Usuario Final (CLUF).