#!/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)