之前要写个探测内网主机存活的bash脚本,一直没写明白,写完文件监控之后突然就写明白了
代码:
#!/bin/bash
# 定义要扫描的IP地址范围
subnet="192.168.$1."
start_ip=1
end_ip=254
# 创建一个空临时文件来保存扫描结果
tmp_file=$(mktemp)
# 循环遍历IP地址范围,并将 ping 命令放入后台执行
for ((ip=$start_ip; ip<=$end_ip; ip++)); do
target_ip="$subnet$ip"
# 使用 ping 命令检测主机是否在线,并将结果保存到临时文件
ping -c 1 -W 1 $target_ip >/dev/null 2>&1 && echo "主机 $target_ip 在线" >> "$tmp_file" &
done
# 等待所有后台进程执行完成
wait
# 输出扫描结果
cat "$tmp_file"
# 删除临时文件
rm "$tmp_file"
直接进程拉满,秒出结果
原理就是用ping探测主机是否存活,并且指定只发送一个数据包,超时为一秒,然后用“&”来实现多进程,用wait等所有ping结束再输出结果
还发现个挺别致的小东西,照着msf里抄的
贴在for循环前边就行:
echo -e "\033[36m开始扫描"
echo " \ ,__,"
echo " \ (oo)____"
echo " (__) )\ "
echo " ||--|| *"
echo "--------------------"