zoukankan      html  css  js  c++  java
  • 静湖ABC段扫描器(长更)

    想学习python图形化的知识,从C段扫描器开始入手,很多的扫描器只能扫描C段,对于A,B段却没有设置这个功能,所以想将扫描A段和B段的功能跟C段一起做了。

    暂时的想法是,先完成C段扫描器,扫描的同时扫描常用端口,对于有相应的IP地址获取其title信息,并且使用爬虫查询其IP地址大概位置。完成C段扫描器之后再完成A,B段扫描器,为了提高扫描速度,使用多线程完善,最后做成图形化界面。

    今天花两个小时先把C段扫描器暂时完成了,粗糙版本,后面再更吧

    扫描器的名字就定为静湖吧,希望可以做好

    import re
    import requests
    from fake_useragent import UserAgent
    from lxml import etree
    port_list=[80, 81, 88, 808, 888, 8000,8008, 8080,8001, 8888, 8020,8009,8081,8082,8083]
    addr_url='http://ip.yqie.com/ip.aspx?ip='
    ua = UserAgent()
    
    def headers_pool():
        headers = {"User-Agent": ua.random}
        return headers
    
    # def A_scan(ip):
    # def B_scan(ip):
    def C_scan(ip):
        ip = ip.split('.')
        host = []
        for tmpIP in range(1, 256):
            ip[-1] = str(tmpIP)
            host.append(".".join(ip))
        return host
    
    def get_addr(ip):
        url = addr_url + ip
        rep = requests.get(url)
        html = etree.HTML(rep.text)
        content = html.xpath('//input[@class="displayno_address"]/@value')[0]
        print ip + "  >>>>>  " + content
    
    def get_rep(ip,port):
        url1 = 'http://' + str(ip) + ':' + str(port)
        url2 = 'https://' + str(ip) + ':' + str(port)
        try:
            rep1 = requests.get(url1,headers=headers_pool(),timeout=3,verify=False)
            if (rep1.status_code==200):
                get_title(url1,rep1)
                get_addr(ip)
        except:
            pass
        try:
            rep2 = requests.get(url2,headers=headers_pool(),timeout=3,verify=False)
            if (rep2.status_code==200):
                get_title(url2,rep2)
                get_addr(ip)
        except:
            pass
    
    def get_title(url,rep):
        title=re.findall(r'<title>(.*?)</title>', rep.text)[0]
        print("[+] "+url+"  >>>>>  "+title)
    
    def check_ip(ip):
        if re.compile(r"^d+.d+.d+.d+$").match(ip):
            return True
        return False
    
    def scan(ip):
        if(check_ip(ip)):
            host=C_scan(ip)
            for url in host:
                for port in port_list:
                    get_rep(url,port)
        else:
            print("ip error!!")
    
    def start():
        print("hello world!")
        print("now please waiting ....")
    
    def main():
        start()
        ip='47.94.132.67'
        scan(ip)
    
    if __name__=='__main__':
        main()
    

      

  • 相关阅读:
    人人都有数字替身的时代马上到来
    教你如何在linux下查看服务是否已经启动或者关闭
    提前了解2019年物联网发展的六大趋势
    本科理工男如何学习Linux
    linux常见命令ps的应用
    useradd 命令的常见用法
    简单聊聊Linux学习经历
    什么是公网IP、内网IP和NAT转换?
    远程获得的有趣的linux命令
    js练习题之查找数组中的位子
  • 原文地址:https://www.cnblogs.com/Cl0ud/p/12528293.html
Copyright © 2011-2022 走看看