Scapy编程指南(基础概念)

Scapy编程指南(基础概念)

Scapy是什么

Scapy是Python中一个非常强大的库,它专门用于处理、发送和捕获网络协议中的数据包,它允许开发人员通过Python代码构建、解析和发送自定义网络协议的数据包。Scapy提供了一种直观、灵活的方式,使用户能够深入研究和操作网络层次的细节。

在这里插入图片描述

一、构造协议数据报文

scapy可以构造各种网络协议的数据包。用户可以使用Scapy定义协议头、字段和载荷,然后构建出符合特定协议规范的数据包。

  1. Ether(): 构造以太网帧。
  2. IP(): 构造IP数据报。
  3. TCP(): 构造TCP报文。
  4. UDP(): 构造UDP报文。
  5. ICMP(): 构造ICMP报文。
  6. ARP(): 构造ARP请求和响应。
  7. Raw() - 构造原始数据包
二、捕获协议数据报文

scapy可以指定计算机网络接口,去捕获该接口传输的协议数据报文,并且能根据规则过滤出需要的协议数据报文。

sniff(): 捕获数据包

三、发送协议数据报文

Scapy提供了多种方式来发送协议数据报文,具体取决于用户的需求和场景。

  1. send() - 发送数据包

  2. sendp() - 发送数据包并在数据包中包含Layer 2头部信息

  3. sr() - 发送并接收数据包,返回接收到的响应

  4. sr1() - 发送并接收数据包,返回第一个接收到的响应

  5. srloop() - 发送并循环接收数据包

  6. sendpfast() - 以更高的速度发送数据包,通常用于性能要求较高的场景。

  7. srp() - 类似于sr(),但是针对数据包进行二层处理,常用于以太网数据包的发送和接收。

  8. sendpfast() - 高速发送数据包,类似于sendp(),但设计用于更高的性能。

四、分析协议数据报文

Scapy提供了多种功能来分析协议数据报文,让用户深入研究和了解网络通信的细节。

  • ls() :用于列出所有已知的协议和字段。该命令的作用是展示协议和字段的层次结构以及它们的关系。

pkt是数据包对象:

  1. pkt.time - 数据包的时间戳。
  2. pkt.len - 数据包的长度。
  3. pkt.summary() - 显示数据包的摘要信息,包括源地址、目标地址等。
  4. pkt.show() - 显示详细的数据包信息,包括协议头、字段和载荷等,它提供了更全面的输出,包括每个字段的详细信息,适合深入分析单个数据包的结构和内容。
  5. pkt.show2()类似show(),不过他显示是简要信息,通常会提供比较简洁的输出,适合在大量数据包中快速查看关键信息。
  6. pkt.haslayer(proto) - 检查数据包是否包含指定的协议层。
  7. pkt.getlayer(proto) - 获取数据包中指定协议层的实例。
  8. pkt.command() - 返回生成当前数据包的Scapy命令。
  9. pkt.hexdump() - 以十六进制格式显示数据包的内容。

网络分层结构

想学好scapy,就必须要对网络报文要有所了解,理解 TCP/IP 协议栈的层次结构对学习 Scapy 和进行网络编程非常重要。TCP/IP 协议栈分为四个层次,从低到高分别是链路层(数据链路层)、网络层、传输层和应用层。这些层次提供了不同的功能,每个层次都有特定的协议和数据单元。

img

在初步学习了Scapy库中的部分常用函数后,一定要对协议数据包进行一定的熟悉,要明白一个数据包要怎么层层封装,在TCP\IP协议族中,是从应用层->传输层->网络层->数据链路层进行封包传输,而在scapy中,却要从Ether(数据链路层)->IP(网络层)->TCP\UDP(传输层)->HTTP/DNS(应用层)进行封装,Scapy构建数据包的过程是从底层到高层逐步封装

  1. 链路层(数据链路层):
    • 功能:处理与物理媒体的通信,负责将数据帧从一个网络设备传输到相邻的网络设备。
    • 协议:Ethernet、ARP(地址解析协议)等。
    • Scapy 对应的对象:Ether()ARP()

image-20240124200651036

  1. 网络层:
    • 功能:提供端到端的数据传输,实现数据包的路由和转发。
    • 协议:IP(Internet 协议)等。
    • Scapy 对应的对象:IP()ICMP()

image-20240124201054792

  1. 传输层:
    • 功能:提供端到端的通信,保证数据的可靠传输。
    • 协议:TCP(传输控制协议)、UDP(用户数据报协议)等。
    • Scapy 对应的对象:TCP()UDP()

image-20240124201032239

  1. 应用层:
    • 功能:为应用程序提供网络服务,处理特定的应用层协议。
    • 协议:HTTP、FTP、DNS 等。
    • Scapy 对应的对象:DNS()HTTP()

image-20240124201222974

使用 Scapy 时,我们可以根据需要构建和操作这些不同层次的数据包。例如,你可以创建以太网帧(Ether())并在其上添加 IP 头(IP())、TCP 头(TCP())等,以模拟整个通信过程。

构造数据包

在Scapy中,可以使用简单而灵活的语法构造各种网络数据包。以下是一些基本的Scapy数据包构造示例:

构造一个简单的IP数据包
from scapy.layers.inet import IP

# 构造一个简单的IP数据包
ip_packet = IP(src="192.168.1.1", dst="192.168.1.2")

# 打印数据包信息
print(ip_packet.show())

image-20240124193120458

构造一个TCP数据包
from scapy.layers.inet import IP, TCP

# 构造一个IP数据包和TCP数据包
tcp_packet = IP(src="192.168.1.1", dst="192.168.1.2") / TCP(dport=80, flags="S")

# 打印数据包信息
print(tcp_packet.show())

image-20240124193208376

构造一个UDP数据包
from scapy.layers.inet  import IP, UDP

# 构造一个IP数据包和UDP数据包
udp_packet = IP(src="192.168.1.1", dst="192.168.1.2") / UDP(dport=53)

# 打印数据包信息
print(udp_packet.show())

image-20240124193244160

构造一个ICMP数据包
from scapy.layers.inet import IP, ICMP

# 构造一个IP数据包和ICMP数据包
icmp_packet = IP(src="192.168.1.1", dst="192.168.1.2") / ICMP()

# 打印数据包信息
print(icmp_packet.show())

image-20240124193354367

构造一个ARP数据包
from scapy.layers.l2 import ARP ,Ether 

#构造ARP请求包
arp_packet = Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst="192.168.1.1")

print(arp_packet.show)

image-20240124193423538

构造一个HTTP数据包
from scapy.layers.all import IP,TCP,HTTP

#构造HTTP请求包
http_packet = IP(dst="192.168.1.1") / TCP(dport=80) /"GET HTTP/1.1\r\nHost:192.168.1.5"

print(http_packet)

image-20240124201854624

总结

Scapy 是一款功能强大的网络工具库,具有灵活性和广泛的协议支持。它提供了丰富的功能,让用户能够直观地操作网络数据包,进行网络分析和实验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/345677.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

luffy商城项目(二)

路飞后端配置 二次封装response drf提供的Response对象,不能很方便的加入code和msg字段,自己封装一个Response类,以后都用我们自己封装的,方便咱们写code和msg 封装步骤: 1 在utils/common_response.py from rest_…

GitLab升级版本(任意用户密码重置漏洞CVE-2023-7028)

目录 前言漏洞分析影响范围查看自己的GitLab版本升级路程 升级过程13.1.1113.8.8 - 14.0.1214.3.614.9.5 - 16.1.6 前言 最近GitLab发了个紧急漏洞需要修复,ok接到命令立刻着手开始修复,在修复之前先大概了解一下这个漏洞是什么东西 漏洞分析 1、组件…

【立创EDA-PCB设计基础】6.布线铺铜实战及细节详解

前言:本文进行布线铺铜实战及详解布线铺铜的细节 在本专栏中【立创EDA-PCB设计基础】前面完成了布线铺铜前的设计规则的设置,接下来进行布线 布局原则是模块化布局(优先布局好确定位置的器件,例如排针、接口、主控芯片&#xff…

《WebKit 技术内幕》学习之十一(2):多媒体

2 视频 2.1 HTML5视频 在HTML5规范定义中,Web开发者可以使用“video”元素来播放视频资源。视频中有个重要的问题就是视频编码格式,对此,目前标准中包含了三种编码格式,它们分别是Ogg、MPEG4和WebM。其中Ogg是由Xiph.org组织开…

(二)CarPlay集成开发之苹果的iAP协议

文章目录 概要协议格式鉴权流程CarPlay中的iAP2协议应用小结 概要 iAP2协议是由苹果公司定义的一种数据通信协议,主要用于苹果设备认证外设,以及与外设数据交换的一种协议 协议格式 协议格式一共分为三种类型,分别为握手包,链路…

「 典型安全漏洞系列 」06.路径遍历(Path Traversal)详解

引言:什么是路径遍历?如何进行路径遍历攻击并规避常见防御?如何防止路径遍历漏洞。 1. 简介 路径遍历(Path Traversal)是一种安全漏洞,也被称为目录遍历或目录穿越、文件路径遍历。它发生在应用程序未正确…

mac电脑安卓文件传输工具:Android File Transfer直装版

Android File Transfer(AFT)是一款用于在Mac操作系统上与Android设备之间传输文件。它允许用户将照片、音乐、视频和其他文件从他们的Android手机或平板电脑传输到Mac电脑,以及将文件从Mac上传到Android设备。 下载地址:https://w…

【立创EDA-PCB设计基础完结】7.DRC设计规则检查+优化与丝印调整+打样与PCB生产进度跟踪

前言:本文为PCB设计基础的最后一讲,在本专栏中【立创EDA-PCB设计基础】前面已经将所有网络布线铺铜好了,接下来进行DRC设计规则检查优化与丝印调整打样与PCB生产进度跟踪 目录 1.DRC设计规则检查 2.优化与丝印调整 1.过孔连接优化 2.泪滴…

如何做好一个信息系统项目经理,一个项目经理的个人体会和经验总结(四)

前言 说完了在 项目开发阶段 我的一些个人体会和经验总结,最后我们聊聊在 项目验收阶段 我们需要关注哪些方面的内容…… 项目验收阶段 系统开发告一段落后,就进入客户培训、系统验收阶段,这个阶段,我一般会注意以下几个问题&a…

NAT配置

目录 静态NAT配置配置抓包测试 动态NAT配置配置测试 Easy IP配置配置测试 静态NAT配置 配置 nat static global { global-address} inside {host-address } 命令用于创建静态NAT。 global参数用于配置外部公网地址。 inside参数用于配置内部私有地址。 AR1-NAT <Huawei&g…

Effective C++——关于重载赋值运算

令operator返回一个*this的引用 在重载,,*等运算符时&#xff0c;令其返回一个指向this的引用。 class MyClass {int* val; public:MyClass(int i) : val(new int(i)){}MyClass():val(new int(0)){}void print() {cout << *val << endl;}MyClass& operator(co…

基于SpringBoot Vue美食网站系统

大家好✌&#xff01;我是Dwzun。很高兴你能来阅读我&#xff0c;我会陆续更新Java后端、前端、数据库、项目案例等相关知识点总结&#xff0c;还为大家分享优质的实战项目&#xff0c;本人在Java项目开发领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目&#x…

Django入门,十分钟学会登录网页

我们假定你已经阅读了 安装 Django。你能知道 Django 已被安装&#xff0c;且安装的是哪个版本&#xff0c;通过在命令提示行输入命令 cmd黑窗口运行&#xff0c;不懂cmd百度一下 python -m django --version 如果没出现版本&#xff0c;就是没安装&#xff0c;那么用pip安装…

什么叫特征分解?

特征分解&#xff08;Eigenvalue Decomposition&#xff09;是将一个方阵分解为特征向量和特征值的过程。对于一个 nn 的方阵A&#xff0c;其特征向量&#xff08;Eigenvector&#xff09;v 和特征值&#xff08;Eigenvalue&#xff09; λ 满足以下关系&#xff1a; 这可以写…

vp9协议笔记

vp9协议笔记&#x1f4d2; 本文主要是对vp9协议的梳理&#xff0c;协议的细节参考官方文档&#xff1a;VP9协议链接&#xff08;需要加速器&#xff09; vp9协议笔记 vp9协议笔记&#x1f4d2;1. 视频编码概述2. 超级帧superframe&#xff08;sz&#xff09;&#xff1a;2. fr…

【码农新闻】浏览器上有趣的 Console 命令,VSCode 插件 FreeWindow......

目录 【码农新闻】浏览器上有趣的 Console 命令,VSCode 插件 FreeWindow...... 浏览器上有趣的 Console 命令VSCode 插件 FreeWindow拖拽竟然还能这样玩!阮一峰 ES6 教程总结学习网站总结与整理买临期食品的年轻人,在向“吃喝内卷”低头文章所属专区 码农新闻 欢迎各位编程大…

100T数据存进服务器分几步?

大家好&#xff0c;我是豆小匠。 这期来聊聊数据存储相关的问题&#xff0c;包括&#xff1a; 容量评估。技术选型。容灾处理。 另外&#xff0c;文末赠送免费定制红包封面哦&#xff01; 1. 容量评估 通过对容量&性能的评估&#xff0c;可以把业务需求转化成技术语言描…

Mysql数据库DQL查询语言之表连接(联合查询)

表连接 关系字段&#xff1a;两表中有关联关系的字段 \关系字段&#xff1a;两表之间存在关系的字段 什么是表连接&#xff1f; 当我们的查询结果需要从多张表中获取时&#xff0c;此时应该让表之间建立连接&#xff0c;同时获取数据 内连接 特点&#xff1a;同时对连接双方做…

SpringBoot集成mybatis时idea控制台中文乱码问题解决

在application.yml中配置好映射文件打印数据库日志文件时&#xff0c;控制台出现乱码的情况解决如下 问题 在执行查询操作的时候&#xff0c;查询时可以查看是没有问题的&#xff0c;但是控制台乱码了 解决 在File-Setting-Editor-File Encodings中设置如图所示就可以了 现在…

打 jar 包运行 在windows 平台控制台和日志 乱码解决

--拒絕鷄巴囉嗦&#xff0c;直接解決問題 我们在Windows下运行jar包时&#xff0c;常常会出现乱码&#xff0c;主要分为dos窗口输出的日志中出现乱码和程序返回数据出现乱码。 dos窗口输出的日志中出现乱码 执行如下命令&#xff0c;将控制台输出编码改为UTF8&#xff1a; ch…