nmap 输出与 awk 到表

nmap 输出与 awk 到表

我正在尝试将nmap输出作为表格或至少是直列。我正在使用这个命令:

$ sudo nmap -sn 192.168.103.0/24 \
    | awk '/Nmap scan report for/{printf $5;}/MAC Address:/{print ","substr($0, index($0,$3)) }' \
    | sort -t . -k 4,4n

但是,我希望它向我展示:

ip    mac address     hostname

没有()IP 或主机名,但我无法做到这一点。

答案1

如果您有能力,xmlstarlet您可以解析 XML 输出nmap并生成几乎任何您想要的表

nmap -sn -oX - 192.168.1.0/24 |
    xmlstarlet sel -t \
            -m '/nmaprun/host[status/@state="up"]' \
            -v 'address[@addrtype="ipv4"]/@addr' -o $'\t' \
            -v 'address[@addrtype="mac"]/@addr' -o $'\t' \
            -v 'hostnames/hostname[1]/@name' -n

XML 输出示例如下所示

<nmaprun scanner="nmap" args="nmap -sn -oX - 192.168.1.0/24" start="1589146436" startstr="Sun May 10 21:33:56 2020" version="7.70" xmloutputversion="1.04">
  <verbose level="0"/>
  <debugging level="0"/>
  <host>
    <status state="up" reason="arp-response" reason_ttl="0"/>
    <address addr="192.168.130.6" addrtype="ipv4"/>
    <address addr="01:55:1E:C3:68:A3" addrtype="mac" vendor="SomeManufacturer"/>
    <hostnames>
      <hostname name="host6.roaima.co.uk" type="PTR"/>
    </hostnames>
    <times srtt="119229" rttvar="119229" to="596145"/>
  </host>
  <host>...</host>
  <host>...</host>
  <runstats>
    <finished time="1589146444" timestr="Sun May 10 21:34:04 2020" elapsed="8.09" summary="Nmap done at Sun May 10 21:34:04 2020; 256 IP addresses (4 hosts up) scanned in 8.09 seconds" exit="success"/>
    <hosts up="4" down="252" total="256"/>
  </runstats>
</nmaprun>

处理后的输出示例,仅显示四个设备响应nmapping 请求

192.168.1.6     01:55:1E:C3:68:A3       host6.roaima.co.uk
192.168.1.8     92:66:9B:20:F1:17
192.168.1.15    53:77:5E:EA:FD:03       client15.roaima.co.uk
192.168.1.31    C4:88:FB:6C:64:AE

xmlstarlet工具使用 XPath 来挑选 XML 元素和属性,或者匹配它们 ( -m) 或提取值 ( -v)。

答案2

如果您确实想使用awk,此脚本可能会有所帮助。

nmap -sn 192.168.1.0/24 |
    awk '
        function out() { if (state=="up") { printf "%s\t%s\t%s\n",ip,mac,name; ip=""; mac=""; name=""; state="" } }

        /Nmap scan report/ { out(); name=$5; ip = substr($6,2,length($6)-2); if (ip=="") { ip=name; name="" } }
        /Host is/ { state=$3 }
        /MAC Address/ { mac=$3 }

        END { out() }
    '

如果需要,可以将其卷成一行。

示例输出,仅显示四个设备响应 pingnmap请求

192.168.1.6     01:55:1E:C3:68:A3       host6.roaima.co.uk
192.168.1.8     92:66:9B:20:F1:17
192.168.1.15    53:77:5E:EA:FD:03       client15.roaima.co.uk
192.168.1.31    C4:88:FB:6C:64:AE

相关内容