位置: 编程技术 - 正文

使用Python3制作TCP端口扫描器(pythonista可以制作app吗)

编辑:rootadmin

推荐整理分享使用Python3制作TCP端口扫描器(pythonista可以制作app吗),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python制作chm,pythontcp编程,python制作chm,python 制作whl,python制作gui,python 制作whl,怎么用python制作简单的程序,怎么用python制作简单的程序,内容如对您有帮助,希望把文章链接给更多的朋友!

在渗透测试的初步阶段通常我们都需要对攻击目标进行信息搜集,而端口扫描就是信息搜集中至关重要的一个步骤。通过端口扫描我们可以了解到目标主机都开放了哪些服务,甚至能根据服务猜测可能存在某些漏洞。 TCP端口扫描一般分为以下几种类型:

TCP connect扫描:也称为全连接扫描,这种方式直接连接到目标端口,完成了TCP三次握手的过程,这种方式扫描结果比较准确,但速度比较慢而且可轻易被目标系统检测到。

TCP SYN扫描:也称为半开放扫描,这种方式将发送一个SYN包,启动一个TCP会话,并等待目标响应数据包。如果收到的是一个RST包,则表明端口是关闭的,而如果收到的是一个SYN/ACK包,则表示相应的端口是打开的。

Tcp FIN扫描:这种方式发送一个表示拆除一个活动的TCP连接的FIN包,让对方关闭连接。如果收到了一个RST包,则表明相应的端口是关闭的。

TCP XMAS扫描:这种方式通过发送PSH、FIN、URG、和TCP标志位被设为1的数据包。如果收到了一个RST包,则表明相应的端口是关闭的。

下面我们将使用Python3 实现TCP全连接端口扫描器,下面进入编程环节。

编码实战

全连接扫描方式的核心就是针对不同端口进行TCP连接,根据是否连接成功来判断端口是否打开,现在我们来实现一个最简单的端口扫描器:

这段代码的核心就是portScanner函数,从其中的内容可以看出,只是进行了简单的TCP连接,如果连接成功则判断为端口打开,否则视为关闭。 我们来看一下运行结果:

使用Python3制作TCP端口扫描器(pythonista可以制作app吗)

这样的扫描看起来效率太低了,实际也确实很慢,因为我们设置了默认的超时时间为1秒,这要是扫描个端口,岂不是要等到花都谢了? 最简单的办法就是用多线程来提高效率,虽然python的多线程有点太弱了,不过至少可以利用我们等待的时间去干点别的。另外之前扫描的端口比较多, 显示的信息我们看起来不方便,这次我们只显示我们关心的打开的端口,并将打开端口的数量在扫描结束的时候显示出来。

运行看一下效果,如下图:

这下看起来是不是方便多了?至此效率上的问题解决了,现在我们还需要为扫描器增加一个 参数解析的功能,这样才能看起来像个样子,总不能每次都改代码来修改扫描目标和端口吧!

参数解析我们将用python3自带的标准模块argparse,这样我们就省去了自己解析字符串的麻烦! 下面来看代码:

看一下运行效果,如下图:

至此我们的端口扫描器就基本完成了,虽然功能比较简单,旨在表达端口扫描器的基本实现思路! 至于更详细的功能可以基于这个基本结构来逐步完善!

小结

本节主要讲解了Python3实现一个简单的端口扫描器的过程,本次实验采用了Tcp全连接的方式,不断尝试连接主机的端口来判断端口的开放情况,虽然存在一些缺点, 不过这种方式最适合初学者学习,至于更复杂的方式以后学习起来也不会很难。想举一反三的朋友可以根据协议和端口的对照关系来完成扫描时同时输出协议, 这样看起来会更好一些,至于更详细的功能就留给大家做练习了!

django使用图片延时加载引起后台错误 环境django1..6缘起今天接到一个任务——解决终端满屏日志中的无用错误。django会尽可能给你准确报出错误位置,但是一些复杂,深层次的错误它自带

Python随机数用法实例详解【基于random模块】 本文实例讲述了Python随机数用法。分享给大家供大家参考,具体如下:1.random.seed(int)给随机数对象一个种子值,用于产生随机序列。对于同一个种子值

Python外星人入侵游戏编程完整版 PYTHON游戏编程外星人入侵的完整实现思路,具体内容如下准备工作:下载python,比如Anaconda3(bit),导入pygame游戏包1.外星人设置,alien.py,代码:impor

标签: pythonista可以制作app吗

本文链接地址:https://www.jiuchutong.com/biancheng/375524.html 转载请保留说明!

上一篇:Python实现将一个大文件按段落分隔为多个小文件的简单操作方法(python中将)

下一篇:django使用图片延时加载引起后台404错误(django图片加载不出来)

  • 附加税减免要做哪些科目
  • 啥叫总分类账
  • 待处理财产损益借贷方向
  • 固定资产折旧准予扣除是什么意思
  • 物流公司主营业务范围
  • 固定资产投资会计处理
  • 1%是什么税
  • 收到上级主管部门拨入的经费
  • 冲销暂估材料怎么做账
  • 节税租赁和销售的区别
  • 补记上年度计提所得税费用的会计分录
  • 企业没有收入怎么办
  • 挂靠工程的所得税账务处理怎么做?
  • 转让无形资产收入属于销售收入吗
  • 资产的税务处理要注意什么
  • 餐饮企业卖套餐赠送单品要交增值税吗?
  • 没有外管证就开具了发票
  • 停车服务费的税率
  • 质量成本包括哪两个成本
  • 资产负债表如何调平
  • 装修待摊费用当月摊销吗
  • 管理费用劳务费现金流
  • Win11 Dev Build 22000.65开发预览版推送(附更新修复已知问题汇总)
  • 资产负债表的编制方法
  • 给客户的贴息的会计处理
  • linux文件权限控制
  • schedulerv2.exe - schedulerv2是什么进程 有什么用
  • thinkphp多数据库连接
  • PHP:zip_entry_filesize()的用法_Zip函数
  • php储存数据的方法
  • 纽约公共图书馆开放时间
  • php zend
  • 小企业会计准则适用于哪些企业
  • 详解Yii2 定制表单输入字段的标签和样式
  • apk文件包下载
  • 什么是免抵调库税额
  • 企业税金总额包括什么
  • 冲暂估会计分录
  • 发生售后维修领用材料分录
  • 累计折旧是当月提还是下月提
  • 主营业务收入未收到钱
  • mysql 5.6安装教程
  • 补计提工资什么意思
  • 出差飞机票会计分录
  • 网约车提现多久到账
  • 费用的分摊要注意什么
  • 租赁合同的印花税怎么交
  • 季报现金流量表可以不填吗
  • 管理费用包含研发费用需要减吗?
  • 去年城建税多计提了怎么办
  • 坏账准备计提方法一经确定不得随意变更这种做法体现了
  • 固定资产净残值率
  • 专项应付款余额转入资本公积的规定
  • 10万以下销售额怎么算
  • 免税蔬菜税额用什么表示
  • 费用报销有哪些
  • MySQL下载安装步骤详解
  • 过滤重复字符串
  • mysql的基本介绍
  • windows图标显示不出来
  • win7系统c盘太满了,如何清理
  • ubuntu如何截图快捷键
  • 主板各个系列详解
  • win7无法访问局域网电脑
  • win10系统玩游戏卡
  • 虚拟机linux使用
  • win7旗舰版怎么进入bios
  • windows7看视频卡顿如何解决
  • 你可能不知道的中融新大
  • Particle system study section 1
  • easyui折叠面板默认折叠
  • Android -- service两种启动方式startService与bindService
  • vue router routes
  • unity怎么学
  • node.js 10实战
  • 在WINDOWS系统中回收站的作用不包括
  • 浅谈自己对教育的理解
  • 消费税的征收范围口诀
  • 为什么国税网上申报不了
  • 金融机构不包括
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设