Python 发包收包利器 - scapy

本文介绍了Python库scapy的使用,包括常用命令、嗅探数据包、构造不同协议的数据包(如IP、ARP、Ether、TCP)、发包收包方法、SYN半开式扫描、数据包序列化与反序列化、字符串转换及离线数据包解析。scapy的强大功能简化了网络通信中的数据包操作。
摘要由CSDN通过智能技术生成

前言

众所周知,我们每天上网都会有很多数据包需要发送,然后处理在接受在发送,这样一个循环往复的过程

图片

这里就显示了很多数据包的发送接收数据,那什么是包呢?下面一起看看

包( packet )是网络通信传输中的数据单位,一般称之为数据包,其主要由源地址,目标地址,净载数据组成

它包括包头和包体,包头是固定长度,包体长度不变

简单了解下包的定义,下面我们来看看发包利器 scapy 的用法吧

 

一、常用命令

1、ls():显示所有支持的数据包对象,可带参数也可不带,参数可以是任意具体的包

图片

可以看出,它包含了全部的内容,如果我们想详细查看某个模块中的内容,比如说我想查看 ARP ,tcp 的话了,可以这样:

图片

在这里要告诉大家的是,我们必须要注意大小写,ls(ARP)这样才可以得出正确结果,ls(arp)是错误的。

 

2、lsc():列出所有函数

图片

满屏的英文,我头都是大的,不知道大家此时此刻是什么样的心情,哈哈哈哈

 

3、hide_defaults():用来删除一些用户提供的那些和 default value 相同的项目

​​​​​​​

a=IP()print(a.hide_defaults())

 

4.display():可以简单查看当前 packet 的各个参数的取值情况,

​​​​​​​

a=IP()a.display()

 

5.更多命令

命令                                  作用show_interfaces()                  显示网卡信息
str(pkt)                            组装数据包
hexdump(pkt)                        十六进制转储
ls(pkt)                          显示出字段值的列表
pkt.summary()                        一行摘要
pkt.show()                      针对数据包的展开视图
pkt.show2()             显示聚合的数据包(例如,计算好了的校验和)
pkt.sprintf()                   用数据包字段填充格式字符串
pkt.decode_payload_as()         改变payload的decode方式
pkt.psdump()                绘制一个解释说明的PostScript图表
pkt.pdfdump()                   绘制一个解释说明的PDF
pkt.command()       
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值