• 静湖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()
    

      

  • 相关阅读:
    Oracle 11g系列:函数与存储过程
    Oracle 11g系列:视图
    Oracle 11g系列:约束
    Oracle 11g系列:数据表对象
    Oracle 11g系列:数据库
    Oracle 11g系列:SQL Plus与PL/SQL
    Ext.util.TaskRunner定时执行任务
    MS SQL Server存储过程
    UML基础:用例图Use Case Diagram(1)
    UML基础系列:类图
  • 原文地址:https://www.cnblogs.com/Cl0ud/p/12528293.html
Copyright © 2020-2023  润新知