基于python的端口扫描_python实现端口扫描

这段代码展示了如何使用Python的socket库和multiprocessing模块进行端口扫描,针对192.168.0.105主机的特定端口进行连接尝试,找出开放的端口,并利用多进程提高扫描效率。80端口被标记为开放,对应的服务是HTTP。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一 代码

import socket

import multiprocessing

def ports(ports_service):

#获取常用端口对应的服务名称

for port in list(range(1,100))+[143,145,113,443,445,3389, 8080]:

try:

ports_service[port] = socket.getservbyport(port)

except socket.error:

pass

def ports_scan(HOST, ports_service):

ports_open = []

try:

sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

#sock.settimeout(60)

except socket.error:

print('socket creation error')

sys.exit()

for port in ports_service:

try:

#尝试连接指定端口

sock.connect((HOST,port))

#记录打开的端口

ports_open.append(port)

sock.close()

except socket.error:

pass

return ports_open

if __name__=='__main__':

m = multiprocessing.Manager()

ports_service = dict()

results = dict()

ports(ports_service)

#创建进程池,允许最多8个进程同时运行

pool = multiprocessing.Pool(processes=8)

net = '192.168.0.'

for host_number in map(str,range(105,106)):

host = net+host_number

#创建一个新进程,同时记录其运行结果

results[host] = pool.apply_async(ports_scan, (host, ports_service))

print('starting '+host+'...')

#关闭进程池,close()必须在join()之前调用

pool.close()

#等待进程池中的进程全部执行结束

pool.join()

#打印输出结果

for host in results:

print('='*30)

print(host,'.'*10)

for port in results[host].get():

print(port, ':', ports_service[port])

二 运行结果

starting 192.168.0.105...

==============================

192.168.0.105 ..........

80 : http

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值