zoukankan      html  css  js  c++  java
  • 调用pythonnmap实现扫描局域网存活主机

    使用环境:Raspberry 3b+ +netifaces+python-nmap+nmap

    调用netifaces自动获取ip地址:

    def get_gateways():
        return netifaces.gateways()['default'][netifaces.AF_INET][0]

    将ip地址生成一个网段中所有ip地址的列表:

    def get_ip_lists(ip):
        ip_lists = []
        for i in range(1, 256):
            ip_lists.append('{}{}'.format(ip[:-1], i))
        return ip_lists

    主要实现代码及数据分割:

    def main(ip=None):
        ip=get_gateways()
        ip_lists=get_ip_lists(ip)
        nmScan,temp_ip_lists,hosts = nmap.PortScanner(),[],ip[:-1]+'0/24'
        ret = nmScan.scan(hosts=hosts, arguments='-sP')
        print('扫描时间:'+ret['nmap']['scanstats']['timestr']+'\n命令参数:'+ret['nmap']['command_line'])
        for ip in ip_lists:
            print('ip地址:'+ip+'')
            if ip not in ret['scan']:
                temp_ip_lists.append(ip)
                print('扫描超时')
            else:print('已扫描到主机,主机名:'+ret['scan'][ip]['hostnames'][0]['name'])
        print(str(hosts) +' 网络中的存活主机:')
        for ip in temp_ip_lists:ip_lists.remove(ip)
        for ip in ip_lists:print(ip)

    完整代码:

    #!/usr/bin/python
    #_*_ coding:utf8 _*_
    import netifaces,nmap
    
    def get_gateways():
        return netifaces.gateways()['default'][netifaces.AF_INET][0]
    
    def get_ip_lists(ip):
        ip_lists = []
        for i in range(1, 256):
            ip_lists.append('{}{}'.format(ip[:-1], i))
        return ip_lists
    
    def main(ip=None):
        ip=get_gateways()
        ip_lists=get_ip_lists(ip)
        nmScan,temp_ip_lists,hosts = nmap.PortScanner(),[],ip[:-1]+'0/24'
        ret = nmScan.scan(hosts=hosts, arguments='-sP')
        print('扫描时间:'+ret['nmap']['scanstats']['timestr']+'\n命令参数:'+ret['nmap']['command_line'])
        for ip in ip_lists:
            print('ip地址:'+ip+'')
            if ip not in ret['scan']:
                temp_ip_lists.append(ip)
                print('扫描超时')
            else:print('已扫描到主机,主机名:'+ret['scan'][ip]['hostnames'][0]['name'])
        print(str(hosts) +' 网络中的存活主机:')
        for ip in temp_ip_lists:ip_lists.remove(ip)
        for ip in ip_lists:print(ip)
    
    if __name__ == '__main__':
        main()

    实验截图:

  • 相关阅读:
    汉英单词对照,汉英部分
    解密SQL Server存储过程等对象
    统计信息对执行计划的影响(二)
    统计信息对执行计划的影响(一)
    asp.net 避免 ajax 定时调用,利用 ashx 实现 long polling (长轮询)
    [ADO.NET][Command]如何抓取第一筆資料的第一個欄位或scalar值?
    鱼骨图
    js 中跳出多层循环
    IIS无法 添加/编辑 应用程序扩展名映射的原因
    如何让域名后面不显示xxx.do后缀
  • 原文地址:https://www.cnblogs.com/wananonline/p/9681729.html
Copyright © 2011-2022 走看看