Como encontrar todos os dispositivos (endereço IP, nome do host, endereço MAC) na rede local?

13

Eu já li quase todos os tópicos relacionados a isso, mas ninguém facilitou o acesso a uma tabela como a seguinte.

  IP Address     Hostname        MAC Address
  192.168.1.10 | myAppleTV     | 02:78:42:9b:bb:12
  192.168.1.10 | myiPhone      | b2:18:4a:3a:42:22
  192.168.1.10 | myiMac        | 09:17:a2:95:c4:00
  192.168.1.10 | myCanonPrinter| a0:ea:72:77:b4:aa

Na maioria das vezes eu uso arp -ae também há dns-sb, mas nenhum deles facilita a descoberta de três informações importantes sempre que estou mexendo na rede, como endereço IP, nome do host e endereço MAC. Estou surpreso que não haja um utilitário que faça isso!

Spectramax
fonte
Esse tipo de informação estará principalmente no roteador
user151019

Respostas:

12

Se o uso de um utilitário de terceiros não for um problema para você, recomendo que experimente:

arp-scan (disponível via Homebrew )

brew install arp-scan
arp-scan --localnet

fing (faça o download e instale o pacote "Desktop Embedded CLI" em fing.com ou via Homebrew brew cask install fing)

sudo fing -r 1 -d true -o table,text

Ambos os utilitários têm vários modos e recursos adicionais. Sugiro a leitura completa dos manuais para tirar o máximo proveito deles.

Se você precisar evitar o uso de ferramentas de terceiros, veja aqui uma maneira de fazer algo semelhante com os comandos internos. Você pode executá-los interativamente, mas provavelmente é mais fácil salvá-lo como um script. Nota: para mantê-lo breve, este script não verifica erros e funciona apenas em sub-redes / 24. Modificá-lo para funcionar em sub-redes de outros tamanhos é deixado como um exercício para o leitor :)

#!/usr/bin/env bash
tab=$'\t'
pIF=$(echo "show State:/Network/Global/IPv4" | scutil | awk -F: '/PrimaryInterface/{sub(/ /,"",$2); print $2}')
sn=$(ipconfig getifaddr $pIF | sed -En 's/^([0-9]+\.[0-9]+\.[0-9]+).*/\1/p')
for i in {1..254}; do ping -i0.1 -W100 -c1 $sn.$i | grep from; done
arp -a | grep $pIF | sed -e 's/^\?/unnamed/' -e "s/\ at\ /${tab}/g" -e "s/\ on\ /${tab}/g" -e 's/\ ifscope.*$//g' | awk 'BEGIN { FS="\t"; OFS="\t"; printf "%-17s\t%-15s\t%s\n", "MAC","INTERFACE","HOSTNAME (IP)" } { if($2!="(incomplete)") {printf "%-17s\t%-15s\t%s\n",$2,$3,$1}}'

Isso deve gerar algo como:

MAC                 INTERFACE       HOSTNAME (IP)
0:90:b:7a:85:62     en0             r1.lan (192.168.20.1)
2c:36:f8:48:2b:47   en0             cisco-sg300-10p.lan (192.168.20.2)
84:78:ac:a6:95:a0   en0             cisco-sg300-20.lan (192.168.20.3)
b4:fb:e4:cb:93:85   en0             wap1.lan (192.168.20.10)
0:11:32:10:cd:c1    en0             nas.lan (192.168.20.20)
0:11:32:3d:99:c9    en0             nas2.lan (192.168.20.21)
0:11:32:10:cd:c1    en0             unnamed (192.168.20.23)
d4:4b:5e:fe:6a:75   en0             brwd44b5efe6a75.lan (192.168.20.90)
luckman212
fonte