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.
- 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].
- 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]:
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.
- A este punto solo queda verificar algunos datos, como verificar si pudo obtener todos los datos de los equipos.