Estou fazendo um scanner de rede que funcionará em qualquer rede. Este é o meu código até agora
fd=$(date +%m%d%y%H%M%S)
echo -e "IP$fd\nReport of IP addresses on this intranet, test started at \n$(date)\n\nThe following IP addresses were found:" > IP$fd.txt
echo -e " Okay. Mind you, this could take a couple of minutes.\nI'll be scanning all 254 possibilities between 192.168.1.1 and 192.168.1.254\nI will ring the system bell when I am done.\nHere we go..."
for i in 192.168.0.{1..254}
do
echo "scanning $i"
if [ "$(ping -q -c1 $i)" ]
then
echo -e "AHA! Got one! ---- $i is up!"
fi
echo "END SCAN"
done
echo -e "That's all I got.\Test completed at\n$(date)\n" >> IP$fd.txt
echo -e \\a
echo -e "Your report is IP$fd.txt, and this is what it says:\n"
exit
Exceto que o problema é que isso só funcionará se o seu intervalo de IP for 192.168.0.1-255. Não retornará nada se o ip for 10.10.10.1.
Existe alguma maneira de obter o alcance da rede dos usuários e aplicá-lo ao meu script?
Editar: estou executando como root
Responder1
Não existe uma maneira portátil.
No Linux, você pode listar todas as sub-redes IPv4 às quais o host pertence usando:
ip -4 route show scope link | awk '{print $1}'
(Observe que pode havermais de um.)
Responder2
Você pode extrair os detalhes atuais da rede da saída deifconfig -a
A partir disso, você poderá configurar variáveis para o seu loop for. Pode ser mais fácil trabalhar com endereços inteiros em vez de quadrantes pontilhados.
Haverá vários intervalos de endereços, alguns deles IPV4 e outros IPV6.
Detectar redes próximas às quais a máquina atual não está diretamente conectada daria muito mais trabalho.