我有一个我在工作中使用的脚本,我想扩展一下。我当前使用的脚本将IP地址作为arg,并将zip文件推送到该设备上的特定目录。该设备是Android设备,我推送到的特定目录用于使用推送的新数据触发设备恢复。
我正在寻找一种方法来扫描网络,识别所有连接的android设备,然后将新的固件推送到每个设备上。由于推送部分已经很容易完成,我需要它来找到一种方法来扫描和识别每个连接的设备的IP。
我想出了:
nmap -sL 10.111.1.0/24 | grep android | grep -oE '([[:digit:]]{1,3}\.){3}[[:digit:]]{1,3}'
它将在网络中跳跃,查找行中包含"android“的任何内容,然后解析并返回这些行的IP地址。问题是,我不知道如何一次获取一个IP地址,并从这里将它们提供给脚本。有什么想法吗?
发布于 2013-06-11 21:56:05
您可以在任何时候使用for循环和子where,只要您想要对管道的结果采取行动:
for ip in $( nmap -sL 10.111.1.0/24 | grep android | grep -oE '([[:digit:]]{1,3}\.){3}[[:digit:]]{1,3}' ); do
echo "W00t! I found this ${ip}"
/path/to/script "${ip}"
done
发布于 2013-06-11 22:08:34
我会使用while循环,并使用一个set来解析从grep获得的任何内容。
(nmap -sL 10.111.1.0/24 | grep android | grep -oE '([[:digit:]]{1,3}\.){3}[[:digit:]]{1,3}' | \
while read -a device; do
echo ${device[0]}
echo ${device[1]}
...
/path/to/script ${device[2]} #the number that represents the ip address (I don t know wich one it will be depends what your grep gives)
done)
现在,您可以获取IP地址并将其推送到脚本中
发布于 2013-06-11 22:22:02
将其读入数组:
read -a devices < <(nmap -sL 10.111.1.0/24 | grep android | grep -oE '([[:digit:]]{1,3}\.){3}[[:digit:]]{1,3}')
然后将其发送到脚本:
/path/to/script "${devices[@]}"
https://stackoverflow.com/questions/17045812
复制相似问题