Scapy 从入门到放弃
0x00 前言
最近闲的没事,抽空了解下地表最强的嗅探和收发包的工具:scapy。scapy是一个python模块,使用简单,并且能灵活地构造各种数据包,是进行网络安全审计的好帮手。
0x01 安装
因为2020年python官方便不再支持python2,所以使用python3安装。

0x02 构造数据包
在构造数据包之前首先导入scapy模块: from scapy.all import *
scapy构造数据包也非常简单,例如使用 IP() 就可以创建一个默认的数据包。使用 ls(IP()) 可以查看IP数据包可以有哪些参数。

其他数据包同理

使用IP(dst="114.114.114.114") 来创建一个目的地址是 114.114.114.114 的数据包,再使用 ls() 可以看到数据包的目的地址已经修改。

也可以使用 show 方法来查看数据包信息。

使用summary()方法查看概要信息。

使用hexdump(pkt)开查看数据包的字节信息

使用 '/' 操作符来给数据包加上一层。例如构造一个TCP数据包,在IP层指明数据包的目的地址。在TCP层可以设定数据包的目的端口等等。UDP数据包同理。

数据包的目标端口可以用范围来表示,发送的时候就会发送dport 不同的多个数据包。

如果设置了多个参数为范围的,最后发送的数据包就是笛卡尔积。

0x03 发送数据包
发送数据包可能需要管理员权限,使用sudo python3 进入python即可。
构造完数据包,就可以发送了。
scapy发送数据包有常用的如下几种方法:
send(pkt) 发送三层数据包,但不会受到返回的结果。
sr(pkt) 发送三层数据包,返回两个结果,分别是接收到响应的数据包和未收到响应的数据包。
sr1(pkt) 发送三层数据包,仅仅返回接收到响应的数据包。
sendp(pkt) 发送二层数据包。
srp(pkt) 发送二层数据包,并等待响应。
srp1(pkt) 发送第二层数据包,并返回响应的数据包
例如,使用sr发送一个数据包,ans为响应的数据包,uans为未响应的数据包。


0x04 应用
1)可以构造数据包来实现一个简单的SYN端口扫描,flags="S" 表示发送SYN数据包。

可以看到在发返回的数据包中,22,445,3389端口返回的flag位为SA,表示这些端口是开放的。而RA表示reset ack, 说明这些端口是关闭的。
2)实现一个基于TCP的traceroute

3) 模拟TCP的三次握手

最后可以看到握手成功后,服务器返回信息中包含了当前端口开放的服务

0x05 其他
scapy 还可以用来读取网络流量包或监听网卡流量。
使用函数rdpcap("/abc/def/xxxx.pcap") 可以读取包的内容,再使用haslayer(TCP)或haslayer(ICMP)等等来判断数据包的类型。
使用sniff(iface="wlan1",count=100,filter="tcp xxxx") 可以监听网卡流量,iface声明监听的网卡,filter是过滤条件,count是符合过滤条件的数据包的个数,达到指定的数据包个数后会停止监听,不设count则没有限制,按ctrl-c 结束监听。
sniff也支持无线网卡的监听模式。
Scapy 从入门到放弃的更多相关文章
- CYQ.Data 从入门到放弃ORM系列:开篇:自动化框架编程思维
		
前言: 随着CYQ.Data 开始回归免费使用之后,发现用户的情绪越来越激动,为了保持这持续的激动性,让我有了开源的念头. 同时,由于框架经过这5-6年来的不断演进,以前发的早期教程已经太落后了,包括 ...
 - [精品书单] C#/.NET 学习之路——从入门到放弃
		
C#/.NET 学习之路--从入门到放弃 此系列只包含 C#/CLR 学习,不包含应用框架(ASP.NET , WPF , WCF 等)及架构设计学习书籍和资料. C# 入门 <C# 本质论&g ...
 - OpenStack从入门到放弃
		
OpenStack从入门到放弃 目录: 为何选择云计算/云计算之前遇到的问题 什么是云计算 云服务模式 云应用形式 传统应用与云感知应用 openstack及其相关组件介绍 flat/vlan/gre ...
 - 绕过校园网的共享限制 win10搭建VPN服务器实现--从入门到放弃
		
一.开篇立论= =.. 上次说到博主在电脑上搭建了代理服务器来绕过天翼客户端的共享限制,然而经过实际测试还不够完美,所以本着生命不息,折腾不止的精神,我又开始研究搭建vpn服务器= =... (上次的 ...
 - 《区块链:从入门到放弃》之obc安装步骤
		
obc安装步骤 朋友们可能会好奇,厨师不研究菜谱怎么改研究兵法了,哈哈,我原本是app出身,最近被安排去预研区块链和比特币技术,2个月下来,颇有斩获.期间得到IBM的CC同学指导我一步一步安装obc的 ...
 - win10搭建代理服务器实现绕过校园网的共享限制--从入门到放弃
		
博主所在学校特别坑爹,校园网被电信一家垄断了,而且最恶心的还是电信要求一条网线只能供一台电脑上网,不许接路由器共享网络= =- (还有电信2M价格是380+每年,20m是500每年,而且网速都很慢= ...
 - WPF从入门到放弃系列第二章 XAML
		
本文是作者学习WPF从入门到放弃过程中的一些总结,主要内容都是对学习过程中拜读的文章的整理归纳. 参考资料 XAML 概述 (WPF):https://msdn.microsoft.com/zh-cn ...
 - Android -- 带你从源码角度领悟Dagger2入门到放弃
		
1,以前的博客也写了两篇关于Dagger2,但是感觉自己使用的时候还是云里雾里的,更不谈各位来看博客的同学了,所以今天打算和大家再一次的入坑试试,最后一次了,保证最后一次了. 2,接入项目 在项目的G ...
 - Android -- 带你从源码角度领悟Dagger2入门到放弃(二)
		
1,接着我们上一篇继续介绍,在上一篇我们介绍了简单的@Inject和@Component的结合使用,现在我们继续以老师和学生的例子,我们知道学生上课的时候都会有书籍来辅助听课,先来看看我们之前的Stu ...
 
随机推荐
- windows nginx 搭建文件服务器(通俗易懂)
			
在一些项目里面,有时候需要访问图片的时候.相信很多人都是的直接把文件放到项目里面的: 今天在这里给大家介绍的是利用nginx 搭建图片服务器,直接访问磁盘上的图片. 方法一(使用root关键字): l ...
 - Spark RDD 到 LabelPoint的转换(包含构造临时数据的方法)
			
题目: 将数据的某个特征作为label, 其他特征(或其他某几个特征)作为Feature, 转为LabelPoint 参考: http://www.it1352.com/220642.html 首先构 ...
 - 005_simulink建立条件子系统
			
1. 条件执行子系统 a) 使能子系统:是控制信号大于零时执行的子系统.在控制信号穿越零点由负变正的时步点上,使能子系统开始执行.只要子系统的控制信号保持正值,使能子系统就会保持在执行的状态 b) ...
 - mongodb 高级聚合查询
			
mongodb高级聚合查询 在工作中会经常遇到一些mongodb的聚合操作,特此总结下.mongo存储的可以是复杂类型,比如数组.对象等mysql不善于处理的文档型结构,并且聚合的操作也比mysq ...
 - Python多线程笔记(二)
			
Lock对象 原语锁(互斥锁)是一个同步原语,状态是"已锁定"或者"未锁定"之一.两个方法acquire()和release()用于修改锁的状态.如果状态为已锁 ...
 - 51nod 1459 & 1212
			
1459 双限制最短路 #include <stdio.h> #include <iostream> #include <vector> #include < ...
 - LibreOJ #516. 「LibreOJ β Round #2」DP 一般看规律
			
二次联通门 : LibreOJ #516. 「LibreOJ β Round #2」DP 一般看规律 /* LibreOJ #516. 「LibreOJ β Round #2」DP 一般看规律 set ...
 - Java 8的Time包常用API
			
Date.Canlender.SimpleDateFormat类在新的Time包面前几乎没有优势 日期LocalDate,时间LocalTime,日期时间LocalDateTime. 时区ZoneId ...
 - gitlab怎么用
			
0101在个人资料里面去设置去找密钥.... 0102 点击生成密钥 0103 在文件夹的命令行输入 ssh-keygen -t rsa -C "your.email@example.com ...
 - checkbox后台传个list显示和回显的页面代码C标签
			
<c:forEach items="${listtest}" var="provinces"> <input type= ...