时间:2021-05-22
本文实例为大家分享了python基于socket实现端口扫描的具体代码,供大家参考,具体内容如下
自学Python一段时间,写个端口扫描器练练手。有什么不足之处,请见谅
这是基于socket函数对端口进行端口扫描
所以,首先要导入socket模块
from socket import *其次,通过正侧表达式来判断输入的是不是IP地址
compile_ip = re.compile( '^(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|[1-9])\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)$')这里是核心代码
# -*- coding: utf-8 -*-from socket import *import refrom pip._vendor.distlib.compat import raw_inputdef portscaner(host,port): try: s = socket(AF_INET, SOCK_STREAM) # 实例化socket s.connect((host,port)) #对对应主机的对应端口发起连接 print('主机%s的%s端口处于打开状态'%(host,port)) s.close() #关闭连接 Export_Data(port) #调用Export_Date except Exception as e: pass #利用异常处理,对无法建立连接的端口pass掉def ChecK_Host(host): #利用正侧表达式匹配host,判断是否符合IP地址的格式 并且输入不为空 compile_ip = re.compile( '^(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|[1-9])\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)$') if compile_ip.match(host) and len(host)!=0: #host符合IP地址的格式且不为空值返回True,否则返回False return True else: return False def Export_Data(port): #导出数据 port = str(port) #将port转换为字符串类型 date = open('Active_Port.txt', 'a') #在文件尾部写入数据,Active_Port.txt,若不存在就新建文件 date.write(port+'\n') #将port并行写入文件 date.close() #不要忘了关闭文件def main(host): #主模块 if ChecK_Host(host): #通过ChecK_Host()函数return 的布尔值进行判断输入的IP地址是否有误 for port in range(1,65536): #这里可以改成1024 portscaner(host, port) print('\n') print('已将结果导出到 Active_Port.txt') else: print('IP地址无错误,请重新输入!!!')if __name__ == '__main__': print('<' * 12 + '单线程端口扫描器' + '>' * 12) host = input('请输入有效的目标IPv4地址:') main(host)raw_input('Press Enter to exit...') #当脚本执行完后,等待键入Enter回车才退出程序(可有可无,主要是为了封装成exe可执行文件后,执行完程序dos界面不自动退出)测试结果
可见目的主机的21端口处于开放状态
扫描结束后,将存活的端口写入到Active_Port.txt
这里没有用到多线程,通过循环,一个一个端口进行连接,扫描速度非常慢。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一个简易的TCP端口扫描器,使用python3实现。需求:扫描目标网站开放哪些端口号,将所有开放的端口号输出。分析:使用socket连接,如果连接成功,认为端口
本文实例为大家分享了python实现端口扫描的具体代码,供大家参考,具体内容如下今天老师上课说的内容,使用多线程+socket写一个端口扫描器写的些许潦草,也没
第一、原理端口扫描的原理很简单,就是建立socket通信,切换不通端口,通过connect函数,如果成功则代表端口开发者,否则端口关闭。所有需要多socket程
本文研究的主要是Python的端口扫描程序,具体实例代码如下。先来看看第一个端口扫描程序代码,获取本机的IP和端口号:importsocketdefget_my
本文实例讲述了Python实现的对本地host127.0.0.1主机进行扫描端口功能。分享给大家供大家参考,具体如下:前面一篇《PythonIP端口扫描工具类》