扫描器篇(九)之利用python socket编写端口扫描器

本文介绍了如何使用Python的socket模块创建一个端口扫描器。通过理解socket的工作流程,结合C/S模式,阐述了服务端和客户端的数据处理流程。文章提供了一个简单的扫描模块和主函数的代码示例,展示端口扫描的实现过程及运行效果。
摘要由CSDN通过智能技术生成

前言

  之前在编写端口扫描的代码时都是使用TCP/UDP协议,
  但是看了很多的代码都是用socket来完成的,所以就
  来学习一下socket编程

什么是socket

  • 网络中的两台主机之间进行通信,本质上是主机中所
    运行的进程之间的通信,两个进程如果需要进行通信
    ,最基本的前提是每一个进程要有一个唯一的标识。
    
  • 在本地进程通信中可以使用PID来唯一标识一个程,
    但PID在 本地是唯一,可以用 "IP地+ 协议+端口号" 
    来组成唯一标识的网络进程,这就是socket
    
  • 无论使用何种网络协议,最本质上都是在进行数据
    的收发,发和收,这两个动作就是socket处理数据
    的主要方式
    

socket的工作流程

  • socket 采用C/S 模式,分为服务端和客户端
  • 服务端数据处理流程
    • 创建socket -> 绑定到地址和端口 -> 等待连接 -> 开始通信-> 关闭连接
  • 客户端数据处理流程
  • 创建socket -> 等待连接 -> 开始通信-> 关闭连接
  • 客户端没有绑定地址和端口,是由于客户端进程采用的是随机端口,当客户端要去连接目标时,会由系统自定分配一个端口号和自身ip地址去组合

实现端口扫描原理

  通过与目标端口进行socket连接,如果能连接的上则端口为开放,反之就是关闭。

代码部分

扫描模块

  • 功能
  1. 与目标主机端口创建socket连接
    
  2. 判断是否能够连接
    
  3. 输出开放端口
    
def connect(ip,port):
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)	# 实例化socket类
    try:
        s.connect((ip,int(port)))	# 连接目标主机,能连接的上即端口开放
        time.sleep(0.1)
        print(ip,port,"is open")

    except:
        pass	# 连接不上直接放弃

    finally:
        s.close()	# 不管是否能连接目标主机都关闭连接

主函数

  • 功能
  1. 接收用户输入的参数
    
  2. 扫描单个ip
    
  3. 扫描整个网段
    
def main():
    parser = OptionParser("Usage:-i <ipaddres>-p <target port> -n network")	# 输出帮助信息
    parser.add_option("-i","--host"
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值