Python扫描IP段查看指定端口是否开放的方法

   本文实例讲述了Python扫描IP段查看指定端口是否开放的方法。分享给大家供大家参考。具体实现方法如下:

  ?

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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83

#!/usr/local/bin/python
#-*- coding: UTF-8 -*-
####################################################################
##################################################
#BLOG:http://hi.baidu.com/alalmn
# Python 扫描IP段 指定端口是否开放
##################################################
import socket
import threading,time
socket.setdefaulttimeout(10) #设置了全局默认超时时间
#查看IP端口是否开放
class socket_port(threading.Thread):
def __init__(self,cond, name):
super(socket_port, self).__init__()
self.cond = cond
self.cond.set()#将标识位设为Ture
self.HOST = name
def run(self):
#time.sleep(1) #确保先运行Seeker中的方法
try:
PORT=21
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((self.HOST,PORT))
print""
print self.HOST,u":",PORT,u"端口开放"
#self.cond.wait()#堵塞线程,直到Event对象内部标识位被设为True或超时(如果提供了参数timeout)。
self.cond.set()#将标识位设为Ture
return 1
except:
print ".",
#print self.HOST,u":",PORT,u"端口未开放"
#self.cond.wait()#堵塞线程,直到Event对象内部标识位被设为True或超时(如果提供了参数timeout)。
self.cond.set()#将标识位设为Ture
return 0
##
#socket_port("192.168.2.1")
#if socket_port("192.168.2.100"):
# print "开放"
#else:
# print "未开放"
def ip2num(ip):
ip = [int(x) for x in ip.split('.')]
return ip[0]<<24 | ip[1]<<16 | ip[2]<<8 | ip[3]
def num2ip(num):
#time.sleep(0.05) #50ms
#time.sleep(0.1) #s
# data='%s.%s.%s.%s' % ( (num & 0xff000000) >> 24,
# (num & 0x00ff0000) >> 16,
# (num & 0x0000ff00) >> 8,
# num & 0x000000ff )
# #socket_port(data) #查看IP端口是否开放
if num>=IPend:
print u"IP导入数组完成"
return '%s.%s.%s.%s' % ( (num & 0xff000000) >> 24,
(num & 0x00ff0000) >> 16,
(num & 0x0000ff00) >> 8,
num & 0x000000ff )
def gen_ip(ip1,ip2): #返回数组
# ip
# global IPend
# start, IPend = [ip2num(x) for x in ip.split('-')]
global IPend
IPend=ip2
return [num2ip(num) for num in range(ip1,ip2+1) if num & 0xff]
import ini
if __name__=='__main__':
ini.ini_get() #读取INI
list_ip=gen_ip(ip2num(ini.IP1),ip2num(ini.IP2))
I1 = 0 #得到list的第一个元素
print u"开始扫描IP"
ip=0
while I1 < len(list_ip):
#print list_ip[I1]
time.sleep(0.3) #确保先运行Seeker中的方法
cond = threading.Event()
hider = socket_port(cond,list_ip[I1])
hider.start()
if ip>=255:
ini.ini_write(list_ip[I1],ini.IP2) #修改INI
print ip
ip=0
ip=ip+1
I1 = I1 + 1 #一层

  ini.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

#!/usr/local/bin/python
#-*- coding: UTF-8 -*-
##################################################
#qq:316118740
#BLOG:http://hi.baidu.com/alalmn
# Python 操作ini文件
# 刚学写的不好请大家见谅
##################################################
IP1="" #扫描IP
IP2="" #当前已经扫到的IP
INITXT="IP.ini" #INI文件名字
import ConfigParser
def ini_get(): #读取INI
try:
global IP1
global IP2
global INITXT
config = ConfigParser.ConfigParser()
config.readfp(open(INITXT))
IP1 = config.get("ipdata","ip1")
IP2 = config.get("ipdata","ip2")
except:
print "读取INI错误"
ini_add("","") #写入INI
 
def ini_add(ip1,ip2): #写入INI
try:
global INITXT
config = ConfigParser.ConfigParser()
config.add_section("ipdata")# 设置section段及对应的值
config.set("ipdata","ip1",ip1)
config.set("ipdata","ip2",ip2)
config.write(open(INITXT, "w"))# 写入文件
except:
print "写入INI错误"
def ini_write(ip1,ip2): #修改INI
try:
global INITXT
config = ConfigParser.ConfigParser()
config.read(INITXT)
if not config.has_section("ipdata"):#看是否存在该Section,不存在则创建
temp = config.add_section("")
config.set("ipdata","ip1",ip1)
config.set("ipdata","ip2",ip2)
config.write(open(INITXT, "r+"))
except:
print "修改INI错误"
ini_add("","") #写入INI
#if __name__=='__main__':
## ini_get() #读取INI
## print IP1
## print IP2
#
## ini_add("222222222","3333333333333") #写入INI
## ini_get() #读取INI
## print IP1
## print IP2
#
# ini_write("999999999","0000000000") #修改INI
# ini_get() #读取INI
# print IP1
# print IP2

  运行:

  代码如下:

  python TCP21.py

  希望本文所述对大家的Python程序设计有所帮助。

时间: 2024-12-22 15:10:51

Python扫描IP段查看指定端口是否开放的方法的相关文章

apache负载均衡时如何根据IP段分配指定Tomcat处理?

问题描述 apache负载均衡时如何根据IP段分配指定Tomcat处理?公司为了降低系统上线风险,希望能本部门员工IP段登录时分配给TomcatA(测试环境)处理,外网用户登录时分配给TomcatB,TomcatC(正式应用环境)处理.急急急.各位大哥帮帮忙. 解决方案 解决方案二:看mod_geoip能否解决你的问题.

Centos系统查看指定端口状态并且kill

查询结果通过管道给grep查找包含特定字符串的进程.管道符"|"用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入 例如查看8083端口的状态: [root@server1 ~]# netstat -apn | grep 8083   tcp  0  0    192.168.2.17:8083    0.0.0.0:*    LISTEN      3877/java [root@server1 ~]# kill -9 3877 补充:pgrep: 一看到pgrep首先

同一域名对应不同IP和访问指定主机文件内容的方法

PHP获取远程主机文件内容方法很多,例如:file_get_contents,fopen 等. <?php echo file_get_contents('http://demo.fdipzone.com/test.php'); ?> 但如果同一域名对应了不同IP,例如 demo.fdipzone.com 对应3个IP192.168.100.101, 192.168.100.102, 192.168.100.103. 则不能使用file_get_contents获取 192.168.100.1

PowerShell脚本开发之批量扫描IP和端口_PowerShell

前面的文章中曾经发布了对指定IP进行批量端口扫描的方法和脚本,过PowerShell收发TCP和UDP消息包的方法以及通过PowerShell尝试登录SQLServer服务的方法,这构成了PSNet程序集用于通过PowerShell对网络状态进行操作.最近在不断尝试之下,找到了对指定范围的IP段进行扫描和对端口进行扫描的方法,本文将会介绍如何通过PowerShell批量扫描IP及其对应的端口. 依然在PSNet程序集的基础上进行扩展,首先在$env:PSSpace/PSNet/TCPOp下创建脚

iptables防火墙只允许指定ip连接指定端口、访问指定网站

  需要开80端口,指定IP和局域网 下面三行的意思: 先关闭所有的80端口 开启ip段192.168.1.0/24端的80口 开启ip段211.123.16.123/24端ip段的80口 # iptables -I INPUT -p tcp --dport 80 -j DROP # iptables -I INPUT -s 192.168.1.0/24 -p tcp --dport 80 -j ACCEPT # iptables -I INPUT -s 211.123.16.123/24 -p

php简单实现屏蔽指定ip段用户的访问

  这里给大家分享的是一个简单的使用php实现的屏蔽指定IP段的代码,非常的实用,有需要的小伙伴可以参考下. 这段时间在统计工具里面总是看到一些未知浏览器.未知操作系统的用户的频繁请求而且ip都在一个段里面,使我产生了一些疑问,这些用户算是有效用户吗.网站访问没有浏览器没有操作系统的记录,我经过几天的分析确认这些访问不是人在访问而是一些机器或者是别人在采集我的站内的东西,萌生了一种屏蔽这个ip的想法. 把统计里面的没有浏览器记录的用户数据导出来看了下屏蔽ip已经不现实了ip不少一百多个,但是仔细

XP系统如何查看全部端口和指定端口

  XP系统如何查看全部端口和指定端口          一.查看本地机器全部端口 我们首先打开开始运行,输入CMD.接着输入命令netstat-aon,并回车.全部端口情况就出来了. 列表"> 二.查看指定的端口 当我们需要查看一个指定的端口时,我们输入命令netstat -aon | findstr "端口号",即可.以80端口为例子,输入命令netstat -aon | findstr "80",回车.

php简单实现屏蔽指定ip段用户的访问_php实例

这段时间在统计工具里面总是看到一些未知浏览器.未知操作系统的用户的频繁请求而且ip都在一个段里面,使我产生了一些疑问,这些用户算是有效用户吗.网站访问没有浏览器没有操作系统的记录,我经过几天的分析确认这些访问不是人在访问而是一些机器或者是别人在采集我的站内的东西,萌生了一种屏蔽这个ip的想法. 把统计里面的没有浏览器记录的用户数据导出来看了下屏蔽ip已经不现实了ip不少一百多个,但是仔细观看不难看出这些ip都集中在某些ip断内.想个办法屏蔽整个ip段的用户,也许会造成一些误杀但是能确保网站流量是

WINDOWS 2003 防火墙设置 只允许 指定IP 访问指定端口

前不久在阿里云买的一个服务器,由于没有设置防火墙,前几天突然提示外地登录,立即关闭了服务器. 第二天修改密码,重新开启不一会又提示在别处登录,当时很是无语啊~~~ 于是就寻找只允许指定IP访问指定端口的方法~~好点的是,终于找到了~哈哈~~ 1.打开控制面板   2.打开防火墙 ,点例外 3.点添加端口   4.输入要控制的端口   5.点更改范围   6.选择自定义列表   7.输入允许访问的IP(格式为:192.168.3.100,192.168.3.101/255.255.255.255)