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

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

免费SSL申请和自动更新

当前是在mac下操作 安装certbot # mac下brew安装即可 brew install certbotcentos 安装 centos安装文档 申请泛解析证书 sudo certbot certonly --manual --preferred-challengesdns -d *.yourdomain.com## 输出 Saving debug log to /var/log/letsencrypt/letsencrypt.lo…

四、Flask学习之JavaScript

四、Flask学习之JavaScript JavaScript,作为一种前端脚本语言,赋予网页生动的交互性和动态性。通过它,开发者能够操作DOM(文档对象模型)实现页面元素的动态改变、响应用户事件,并借助AJAX技术实现异步数据…

云计算项目五:部署数据库服务mysql |部署共享存储服务NFS | 配置网站服务

部署数据库服务mysql |部署共享存储服务NFS | 配置网站服务 案例1:配置逻辑卷步骤一:创建LV步骤二:格式化案例2:配置数据库服务器步骤一:安装软件MySQL服务软件(2台数据库服务器都要安装)步骤二:挂载lv设备步骤三:启动服务步骤四:管理员登录案例3:配置主从同步步骤一…

网工内推 | 国企、合资公司IT专员,13薪,NA以上即可

01 上海新徐汇(集团)有限公司 招聘岗位:IT运维 职责描述: 1.负责制定网络体系搭建、IP地址分配、网络拓扑图、无线网络等; 2.负责桌面运维技术支持,确保各类系统和终端设备正常工作; 3.负责弱电…

【并发编程】活锁

📝个人主页:五敷有你 🔥系列专栏:并发编程 ⛺️稳重求进,晒太阳 活锁 定义:活锁出现在两个线程互相改变对象的结束条件,最后谁也无法结束 代码示例 public class TestLiveLock {stati…

微机原理常考填空以及注意事项第(三)弹~

前面已经总结了200个常考题注意事项,可以翻阅查看。 以下仅个人总结的易错以及注意事项: 1,汇编语言源程序的基本格式: DATA SEGMENT;存放数据项的数据段 DATA ENDS EXTRA SEGMENT;存放数据项的附加段 EXTRA ENDS STACK1 SEGM…

React实现字符串首字母大写、翻转字符串、获取用户选定的文本

目录 React实现字符串首字母大写React实现翻转字符串React获取用户选定的文本 React实现字符串首字母大写 import React, { useState } from reactfunction App() {const [inputText, setInputText] useState()const [outputText, setOutputText] useState()const handleInpu…

编辑图片加文字的软件?分享4款!

在数字时代,图片和文字的结合已经成为信息传递的重要方式。为了满足广大自媒体人和内容创作者的需求,本文将为您推荐几款编辑图片加文字的软件,帮助您轻松实现创意表达。 魔法抠图大师 作为一款专业的图片编辑软件,还提供了多种编…

四、MyBatis 动态语句

本章概要 动态语句需求和简介if 和 where 标签set 标签trim 标签(了解)choose/when/otherwise 标签foreach 标签sql 片段 4.1 动态语句需求和简介 经常遇到很多按照很多查询条件进行查询的情况,比如智联招聘的职位搜索等。其中经常出现很多条件不取值的情况&#…

IDEA插件(MyBatis Log Free)

引言 在Java开发中,MyBatis 是一款广泛使用的持久层框架,它简化了SQL映射并提供了强大的数据访问能力。为了更好地调试和优化MyBatis应用中的SQL语句执行,一款名为 MyBatis Log Free 的 IntelliJ IDEA 插件应运而生。这款插件旨在帮助开发者…

STM32F407移植OpenHarmony笔记1

参考文档: OpenAtom OpenHarmonywidthdevice-width,initial-scale1.0https://docs.openharmony.cn/pages/v3.2/zh-cn/device-dev/get-code/gettools-acquire.md/ 搭建环境 安装linux系统: Ubuntu 22.04.2 LTS (GNU/Linux 5.15.0-91-generic x86_64) 下载源代码&a…

2分钟搞定《幻兽帕鲁》联机服务,真爽!

2分钟搞定《幻兽帕鲁》联机服务,真爽!教程 https://t.aliyun.com/U/DKivPS 幻兽帕鲁是Pocketpair开发的一款开放世界生存制作游戏,游戏于2024年1月18日发行抢先体验版本。游戏中,玩家可以在广阔的世界中收集神奇的生物“帕鲁”&a…