本文研究的主要是Python的端口扫描程序,具体实例代码如下。
先来看看第一个端口扫描程序代码,获取本机的IP和端口号:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
import socket def get_my_ip(): try : csock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) csock.connect(( '8.8.8.8' , 80 )) (addr, port) = csock.getsockname() csock.close() return addr,port except socket.error: return "127.0.0.1" def int_to_ip(int_ip): return socket.inet_ntoa(struct.pack( 'I' , socket.htonl(int_ip))) def ip_to_int(ip): return socket.ntohl(struct.unpack( "I" , socket.inet_aton( str (ip)))[ 0 ]) (ip,port) = get_my_ip() print "ip=%s port=%d" % (ip,port) |
PortScan.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
#!/usr/bin/python # -*- coding: utf-8 -*- import optparse from socket import * from threading import * screenLock = Semaphore(value = 1 ) def connScan(tgtHost, tgtPort): try : connSkt = socket(AF_INET, SOCK_STREAM) connSkt.connect((tgtHost, tgtPort)) connSkt.send( 'ViolentPython\r\n' ) results = connSkt.recv( 100 ) screenLock.acquire() print '[+] %d/tcp open' % tgtPort print '[+] ' + str (results) except : screenLock.acquire() print '[-] %d/tcp closed' % tgtPort finally : screenLock.release() connSkt.close() def portScan(tgtHost, tgtPorts): try : tgtIP = gethostbyname(tgtHost) except : print "[-] Cannot resolve '%s': Unknown host" % tgtHost return try : tgtName = gethostbyaddr(tgtIP) print '\n[+] Scan Results for: ' + tgtName[ 0 ] except : print '\n[+] Scan Results for: ' + tgtIP setdefaulttimeout( 1 ) for tgtPort in tgtPorts: t = Thread(target = connScan,args = (tgtHost, int (tgtPort))) t.start() def main(): parser = optparse.OptionParser( 'usage %prog ' + \ '-H <target host> -p <target port>' ) parser.add_option( '-H' , dest = 'tgtHost' , type = 'string' ,\ help = 'specify target host' ) parser.add_option( '-p' , dest = 'tgtPort' , type = 'string' ,\ help = 'specify target port[s] separated by comma' ) (options, args) = parser.parse_args() tgtHost = options.tgtHost tgtPorts = str (options.tgtPort).split( ',' ) if (tgtHost = = None ) | (tgtPorts[ 0 ] = = None ): print parser.usage exit( 0 ) portScan(tgtHost, tgtPorts) if __name__ = = '__main__' : main() |
基于Python socket的端口扫描程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
#------------------------------------------------------------------------------- # Name: PortScan # Purpose: 扫描网段主机的端口开放情况 # Author: Hao Chen # Python3.4 #------------------------------------------------------------------------------- import socket def main(): ip_start = input ( '请输入开始IP:(默认:127.0.0.1)' ) if ip_start = = '': ip_start = '127.0.0.1' ip_end = '127.0.0.1' else : ip_end = input ( '请输入结束IP:' ) if ip_end = = '': ip_end = '127.0.0.1' s = input ( '请输入目标主机开始端口:(默认扫描常用端口)' ) if s = = '': portList = [ 21 , 22 , 23 , 25 , 80 , 135 , 137 , 139 , 445 , 1433 , 1502 , 3306 , 3389 , 8080 , 9015 ] else : startport = int (s) s = input ( '请输入目标主机结束端口:(默认:65535)' ) if s = = '': endport = 65535 else : endport = int (s) portList = [i for i in range (startport,endport + 1 )] while 1 : #ip_start<ip_end x1 = ip_start.rfind( '.' ); x2 = ip_end.rfind( '.' ) if int (ip_start[x1 + 1 :])> int (ip_end[x2 + 1 :]): break ; #开始扫描端口 for port in portList: print ( '正在扫描%s :%d' % (ip_start,port)) try : sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sk.settimeout( 10 ) sk.connect((ip_start,port)) sk.settimeout( None ) print ( 'Server %s port %d OK!' % (ip_start,port)) sk.close() #结果保存在文件中 f = open ( "IP_Port.txt" , 'a' ) f.write(ip_start + ' : ' + str (port) + '\n' ) f.close() except Exception: print ( 'Server %s port %d is not connected!' % (ip_start,port)) #更新ip_start i = ip_start.rfind( '.' ) x = int (ip_start[i + 1 :]) + 1 ip_start = ip_start[:i + 1 ] + str (x) print ( '扫描完成,结果保存在IP_Port.txt文件中' ) if __name__ = = '__main__' : main() |
总结
以上就是本文关于基于Python socket的端口扫描程序实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/cighao/article/details/44731709