python扫描端口脚本

#!/usr/bin/python
#coding=utf-8
'''
一、socket模块的类方法:
socket.socket(family,type)——创建并返回一个新的socket对象
socket.getfqdn(name)——将使用点好分割的IP地址字符串转换成一个完整的域名
socket.gethostbyname(name)——将主机名解析为一个使用点号分隔的IP地址字符串
socket.fromfd(fd,family,type)——从现有文件描述符创建一个socket对象
二、socket模块的实例方法:
sock.bind((adrs,port))——将socket绑定到一个地址和端口上
sock.accept()——返回一个客户机socket(带有客户机端的地址信息)
sock.listen(backlog)——将socket设置成监听模式,可以监听backlog外来的链接请求
sock.connect((adrs,port))——将socket连接到定义的主机和端口上
sock.recv(buflen[,flags])——从socket中接受数据,最多buflen个字符
sock.send(data[,flags])——通过socket发送数据
sock.close()——关闭socket
sock.getsockopt(lvl,optname)——获得指定socket选项的值
sock.setsockopt(lvl,optname)——设定制定socket选项的值
'''
import socket, time, thread
socket.setdefaulttimeout(3)
def socket_port(ip,port):
    """
    输入IP和端口号,扫描判断端口是否开放
    """
    try:
        if port>=65535:
            print u'端口扫描结束'
        s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        result=s.connect_ex((ip,port))
        if result==0:
            lock.acquire()
            print  ip,u':',port,u'端口开放'
            lock.release()
        s.close()
    except:
        print u'端口扫描异常'
def ip_scan(ip):
    """
    输入IP,扫描IP的0-65534端口情况
    """
    try:
        print u'开始扫描 %s' % ip
        start_time=time.time()
        #for i in range(0,65534):
        for i in range(0,3308):
            thread.start_new_thread(socket_port,(ip,int(i)))
        print u'扫描端口完成,总共用时 :%.2f' %(time.time()-start_time)
        raw_input("Press Enter to Exit")
    except:
        print u'扫描ip出错'
if __name__=='__main__':
    url=raw_input('Input the ip you want to scan:\n')
    lock=thread.allocate_lock()
    ip_scan(url)
以上是 python扫描端口脚本 的全部内容, 来源链接: utcz.com/z/387921.html

