2

Я делаю сетевой сканер, который будет работать в любой сети. Это мой код до сих пор

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

За исключением проблемы, что это будет работать, только если ваш диапазон IP-адресов 192.168.0.1-255. Ничего не вернется, если ip равен 10.10.10.1.

Могу ли я в любом случае получить диапазон пользователей сети и применить его к моему сценарию?

Редактировать: я работаю как root

2 ответа2

1

Нет портативного способа.

В Linux вы можете перечислить все подсети IPv4, к которым принадлежит хост:

ip -4 route show scope link | awk '{print $1}'

(Обратите внимание, что их может быть несколько ).

0

Вы можете извлечь текущие сведения о сети из вывода ifconfig -a

После этого вы сможете установить переменные для цикла for. Может быть проще работать с целочисленными адресами, чем с точечными квадратами.

Будет несколько диапазонов адресов, некоторые из них IPV4 и некоторые IPV6.

Чтобы обнаружить близлежащие сети, к которым текущая машина не подключена напрямую, потребовалось бы гораздо больше работы.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .