Inicio Soporte Técnico Obtener dirección IP, Subnet, Gateway, Servidor DNS y MAC de todos los...

Obtener dirección IP, Subnet, Gateway, Servidor DNS y MAC de todos los equipos en la Red

4185
0

Tener la información completa de la configuración de Red de cada equipo es primordial para tener un buen control la Red local de una empresa, asi que para obtener dirección IP, Subnet, Gateway, Servidor DNS y MAC tenemos varias opciones para obtener información remotamente y obtener esta en un archivo Excel, el cual esto simplifica bastante nuestro trabajo y optimiza el tiempo de elaboración, tenemos varias herramientas que Windows nos ofrece, en este caso hablamos de PowerShell, veamos como nos ayuda a realizar esta tarea.

 

Script Powershell

[cmdletbinding()]
param (
 [parameter(ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true)]
    [string[]]$ComputerName = $env:computername
)            

begin {}
process {
 foreach ($Computer in $ComputerName) {
  if(Test-Connection -ComputerName $Computer -Count 1 -ea 0) {
   $Networks = Get-WmiObject Win32_NetworkAdapterConfiguration -ComputerName $Computer | ? {$_.IPEnabled}
   foreach ($Network in $Networks) {
    $IPAddress  = $Network.IpAddress[0]
    $SubnetMask  = $Network.IPSubnet[0]
    $DefaultGateway = $Network.DefaultIPGateway
    $DNSServers  = $Network.DNSServerSearchOrder
    $IsDHCPEnabled = $false
    If($network.DHCPEnabled) {
     $IsDHCPEnabled = $true
    }
    $MACAddress  = $Network.MACAddress
    $OutputObj  = New-Object -Type PSObject
    $OutputObj | Add-Member -MemberType NoteProperty -Name ComputerName -Value $Computer.ToUpper()
    $OutputObj | Add-Member -MemberType NoteProperty -Name IPAddress -Value $IPAddress
    $OutputObj | Add-Member -MemberType NoteProperty -Name SubnetMask -Value $SubnetMask
    $OutputObj | Add-Member -MemberType NoteProperty -Name Gateway -Value ($DefaultGateway -join ",")
    $OutputObj | Add-Member -MemberType NoteProperty -Name IsDHCPEnabled -Value $IsDHCPEnabled
    $OutputObj | Add-Member -MemberType NoteProperty -Name DNSServers -Value ($DNSServers  -join ",")
    $OutputObj | Add-Member -MemberType NoteProperty -Name MACAddress -Value $MACAddress
    $OutputObj
   }
  }
 }
}            

end {}

 Instrucciones de Uso

  • Para hacer uso de Powershell debemos tener instalado Windows Management Framework.
  • Copiamos el script anterior, lo pegamos en un notepad y lo guardamos con extensión NombreArchivo.ps1 o descargamos el archivo ya creado a continuación.
[wpfilebase tag=file id=71 /]
  • Ahora crearemos el listado en un archivo TXT (notepad) de todos los equipos de nuestra red o de los equipos que deseamos obtener la información, el archivo debe contener los nombres de los equipos como se muestra en la imagen y guardamos este  [Ver como crear inventario de red automático]. Ejemplo TXT Inventario
  • Una vez creados guardamos los archivos en una carpeta de fácil acceso por medio de comando por ejemplo alguna carpeta en el C: en mi caso tengo una carpeta en el C:  llamada Scripts.
  • Ahora abrimos Powershell donde ejecutaremos el script con el siguiente comando [Posible error al ejecutar ver aquí como solucionarlo]:
Te recomendamos  Programar inicio automático de programas al arrancar Windows

get-Content C:NombreArchivoListaPCs.txt | C:ScriptsNombreArchivoScript.ps1

  • Si lo queremos exportar a un documento Excel ejecutamos la siguiente linea:

get-Content C:NombreArchivoListaPCs.txt | C:ScriptsNombreArchivoScript.ps1 | Export-csv C:Equipos_IP_FIJA_DINAMICA.csv -notype

  • El cual obtendremos la información que deseamos obtener de la siguiente forma.Archivo Exportado Ejemplo
  •  A este punto solo queda verificar algunos datos, como verificar si pudo obtener todos los datos de los equipos.