Webug4.0靶场通关笔记19- 第24关邮箱轰炸

news2025/7/14 11:20:47

目录

第24关 邮箱轰炸

1.配置环境

2.打开靶场

3.源码分析

4.邮箱轰炸

(1)注册界面bp抓包

(2)发送到intruder

(3)配置position

(4)配置payload

(5)开始轰炸

5.防范措施


第24关 邮箱轰炸

本文通过《webug4靶场第24关 邮箱轰炸》来进行邮箱轰炸攻击渗透实战。

邮箱轰炸是一种网络攻击手段,攻击者利用特殊的软件或工具,向目标邮箱发送大量的电子邮件,从而使目标邮箱服务器不堪重负,导致系统瘫痪或影响用户正常使用邮箱。通常邮箱注册界面都会向其发送邮件,邮箱轰炸攻击主要是利用网站注册功能不对邮箱真实性验证(验证码)和同一机器请求频次验证(验证码发送间隔)造成的漏洞,实现利用网站邮件服务对其他目标邮箱发动轰炸。

  • 攻击者通常会使用邮件群发软件或脚本,这些工具可以自动生成大量的邮件,并以较高甚至极高的频率发送到目标邮箱。邮件的内容可能是随机的,也可能包含恶意信息。有些攻击还会利用邮件服务器的脆弱性,绕过验证机制,进一步增加攻击的强度。

1.配置环境

本靶场要求php版本号大于5.4,需要将靶场的PHP服务版本更新,以phpstudy为例,具体操作方法为“网站-管理-php版本-选择php5.4以上的版本”,具体如下所示。

2.打开靶场

打开webug4靶场,进入第24关邮箱轰炸,完整UR如下所示L。

http://192.168.71.1/webug4/control/auth_cross/email.php

进入24关后是一个会员登录的页面,需要输入用户名和密码,猜测是邮件的登录页面。 

3.源码分析

然后我们找到24关卡对应的源码对其进行代码审计,具体如下所示。

<?php

require_once "../../common/common.php";
require_once("../email.class.php");

if (!isset($_SESSION['user'])) {
    header("Location:../login.php");
}

if (isset($_POST['username'])) {
    if (!empty($_POST['username'])) {
        $email_addr = $_POST['username'];
        $smtpServer="smtp.126.com";
        $smtpServerPort="25";
        $smtpUserMail="webug226@126.com";
        $mailTo=$email_addr;
        $user="webug226";
        $mailPwd="wangai123";
        $mailTitle="hello world";
        $mailContent='<h1>测试邮件</h1>';
        $mailType="HTML";
        // true表示是否身份验证
        $smtp=new \smtp($smtpServer,$smtpServerPort,true,$user,$mailPwd);
        // 是否显示调试信息
        $smtp->debug=false;
        // 返回 bool
        $state=$smtp->sendmail($mailTo,$smtpUserMail,$mailTitle,$mailContent,$mailType);
    }
}


require_once TPMELATE."/email.html";


接下来对如上代码进行详细的注释,具体效果如下所示。

// 检查是否提交了username参数
if (isset($_POST['username'])) {
    // 检查username参数是否非空
    if (!empty($_POST['username'])) {
        // 获取用户输入的邮箱地址(未做任何验证)
        $email_addr = $_POST['username'];
        
        // SMTP服务器配置(硬编码敏感信息)
        $smtpServer="smtp.126.com";       // SMTP服务器地址
        $smtpServerPort="25";              // SMTP端口
        $smtpUserMail="webug226@126.com";  // 发件邮箱(暴露在代码中)
        $mailTo=$email_addr;               // 收件人(用户输入直接使用)
        $user="webug226";                  // SMTP用户名(硬编码)
        $mailPwd="wangai123";              // SMTP密码(明文硬编码,严重安全问题)
        $mailTitle="hello world";          // 邮件标题
        $mailContent='<h1>测试邮件</h1>';  // 邮件内容
        $mailType="HTML";                  // 邮件类型
        
        // 创建SMTP实例(开启认证)
        $smtp=new \smtp($smtpServer,$smtpServerPort,true,$user,$mailPwd);
        $smtp->debug=false;  // 关闭调试信息
        
        // 发送邮件(无频率限制)
        $state=$smtp->sendmail($mailTo,$smtpUserMail,$mailTitle,$mailContent,$mailType);
    }
}

 如上所示,确实没有对注册用户的邮件等参数进行过滤,比如说如下语句

$email_addr = $_POST['username'];

另外就是关于发送邮件的账户信息要配置正确,否则无法成功发送邮件

邮箱轰炸攻击存在的原因如下所示。

  • 无收件人验证:直接使用用户输入的username作为收件地址,未验证是否为合法邮箱格式

  • 无发送频率限制:可无限次触发邮件发送

  • 敏感信息硬编码:SMTP账号密码明文存储在代码中

  • 无CAPTCHA验证:缺少人机验证机制

4.邮箱轰炸

(1)注册界面bp抓包

如下所示输入注册邮箱和密码后点击注册,使用bp抓包

(2)发送到intruder

(3)配置position

如下所示配置为sniper模式,清空所有参数

(4)配置payload

配置为Null Payloads模式,由于是示例这里只轰炸十次,故而生成次数添加10,之后选择攻击

(5)开始轰炸

如下所示轰炸了10次,当然这里只是举个例子,实际上要求邮箱服务器配置正确真正可以发送邮件才可以,不过我们的目的是掌握暴力轰炸的原理,故而这一关卡做到此程度即可。

 

5.防范措施

  • 使用邮件过滤系统:大多数邮箱服务提供商都提供了一定程度的邮件过滤功能,可以设置规则来过滤掉来自特定发件人、包含特定关键词或具有异常特征的邮件。用户也可以安装第三方的邮件过滤软件,进一步增强过滤效果。
  • 限制邮件接收频率:一些邮箱服务器可以设置限制,例如每分钟或每小时允许接收的最大邮件数量。这样可以防止短时间内大量邮件的涌入,减轻服务器的负担。
  • 提高安全意识:用户要保持警惕,不随意在不可信的网站上留下自己的邮箱地址,避免成为攻击目标。同时,对于来源不明的邮件要谨慎处理,不要轻易点击邮件中的链接或下载附件。
  • 及时更新邮箱系统和相关软件:软件开发者会不断修复系统漏_洞,用户及时更新邮箱系统和相关软件,能够确保系统具有最新的安全防护功能,降低被攻击的风险。

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

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

相关文章

java CompletableFuture 异步编程工具用法1

1、测试异步调用&#xff1a; static void testCompletableFuture1() throws ExecutionException, InterruptedException {// 1、无返回值的异步任务。异步线程执行RunnableCompletableFuture.runAsync(() -> System.out.println("only you"));// 2、有返回值的异…

若依框架Ruoyi-vue整合图表Echarts中国地图标注动态数据

若依框架Ruoyi-vue整合图表Echarts中国地图 概述创作灵感预期效果整合教程前期准备整合若依框架1、引入china.json2、方法3、data演示数据4、核心代码 完整代码[毫无保留]组件调用 总结 概述 首先&#xff0c;我需要回忆之前给出的回答&#xff0c;确保这次的内容不重复&#…

算法中的数学:约数

1.求一个整数的所有约数 对于一个整数x&#xff0c;他的其中一个约数若为i&#xff0c;那么x/i也是x的一个约数。而其中一个约数的大小一定小于等于根号x&#xff08;完全平方数则两个约数都为根号x&#xff09;&#xff0c;所以我们只需要遍历到根号x&#xff0c;然后计算出另…

[监控看板]Grafana+Prometheus+Exporter监控疑难排查

采用GrafanaPrometheusExporter监控MySQL时发现经常数据不即时同步&#xff0c;本示例也是本地搭建采用。 Prometheus面板 1&#xff0c;Detected a time difference of 11h 47m 22.337s between your browser and the server. You may see unexpected time-shifted query res…

LaTeX印刷体 字符与数学符号的总结

1. 希腊字母&#xff08;Greek Letters&#xff09; 名称小写 LaTeX大写 LaTeX显示效果Alpha\alphaAαα, AABeta\betaBββ, BBGamma\gamma\Gammaγγ, ΓΓDelta\delta\Deltaδδ, ΔΔTheta\theta\Thetaθθ, ΘΘPi\pi\Piππ, ΠΠSigma\sigma\Sigmaσσ, ΣΣOmega\omeg…

剥开 MP4 的 千层 “数字洋葱”:从外到内拆解通用媒体容器的核心

在当今数字化时代&#xff0c;MP4 格式随处可见&#xff0c;无论是在线视频、手机拍摄的短片&#xff0c;还是从各种渠道获取的音频视频文件&#xff0c;MP4 都占据着主流地位。它就像一个万能的 “数字媒体集装箱”&#xff0c;高效地整合和传输着各种视听内容。接下来&#x…

从彼得·蒂尔四象限看 Crypto「情绪变迁」:从密码朋克转向「标准化追求者」

作者&#xff1a;Techub 精选编译 撰文&#xff1a;Matti&#xff0c;Zee Prime Capital 编译&#xff1a;Yangz&#xff0c;Techub News 我又带着一篇受彼得蒂尔&#xff08;Peter Thiel&#xff09;启发的思想杂烩回来了。作为自封的「蒂尔学派」信徒&#xff0c;我常透过他…

Java线程安全问题深度解析与解决方案

一、线程安全问题的本质 并发编程的核心挑战&#xff1a;当多个线程同时访问共享资源时&#xff0c;由于操作系统的抢占式调度特性&#xff0c;可能导致不可预期的结果。这种因非原子操作和竞态条件引发的数据不一致问题&#xff0c;称为线程安全问题。 二、经典线程安全问题案…

Mybatis解决以某个字段存在,批量更新,不存在批量插入(高效)(一)

背景 在开发企业级应用时&#xff0c;我们经常需要处理批量数据的插入和更新操作。传统的逐条处理方式性能低下&#xff0c;而简单的REPLACE INTO或INSERT ... ON DUPLICATE KEY UPDATE在某些场景下又不够灵活。本文将介绍一种基于临时表的高效批量插入/更新方案&#xff0c;解…

【时时三省】(C语言基础)怎样定义和引用二维数组

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 有的问题需要用二维数组来处理。例如&#xff0c;有3个小分队&#xff0c;每队有6名队员&#xff0c;要把这些队员的工资用数组保存起来以备查。这就需要用到二维数组&#xff0c;如下图&…

杨校老师竞赛课之C++备战蓝桥杯初级组省赛

目录 1. 灯塔 题目描述 输入描述 输出描述 输入样例1 输出样例1 输入样例2 输出样例2 数据说明 2. 子区间 题目描述 输入描述 输出描述 输入样例 输出样例 数据说明 3. 染色 题目描述 输入描述 输出描述 输入样例1 输出样例1 输入样例2 输出样例2 数据…

Matlab 基于Hough变换的人眼虹膜定位方法

1、内容简介 Matlab220-基于Hough变换的人眼虹膜定位方法 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略

vfrom表单设计器使用事件机制控制字段显示隐藏

1. 使用表单设计器进行debug调试 依据 vform3.0开发者文档 https://www.ganweicloud.com/docs/6.1.0/pages/d3e6d9/ 对switch组件设置事件逻辑 调试中

【Redis篇】linux 7.6安装单机Redis7.0(参数优化详解)

&#x1f4ab;《博主主页》&#xff1a; &#x1f50e; CSDN主页 &#x1f50e; IF Club社区主页 &#x1f525;《擅长领域》&#xff1a;擅长阿里云AnalyticDB for MySQL(分布式数据仓库)、Oracle、MySQL、Linux、prometheus监控&#xff1b;并对SQLserver、NoSQL(MongoDB)有了…

信号的概念及产生

信号的概念 信号&#xff08;signal&#xff09;是一种软件中断机制&#xff0c;用于通知进程发生了特定的事件。信号可以由系统、其他进程或进程自身发送。 在现实生活中&#xff0c;也有许多的信号&#xff0c;比如说&#xff1a;红绿灯、闹钟、上课铃、父母喊你回家吃饭等等…

巧用python之--模仿PLC(PLC模拟器)

工作中用到了VM(VisionMaster4.3)有时候需要和PLC打交道,但是PLC毕竟是别人的,不方便修改别人的程序,这时候需要一个灵活的PLC模拟器是多么好呀! 先说背景: PLC型号 汇川Easy521: Modbus TCP 192.168.1.10:502 在汇川Easy521中Modbus保持寄存器D寄存器 ,在modbus协议中 0-4区…

【计算机网络】用户从输入网址到网页显示,期间发生了什么?

1.URL解析 浏览器分解URL&#xff1a;https://www.example.com/page 协议&#xff1a;https域名&#xff1a;www.example.com路径&#xff1a;/page 2.DNS查询&#xff1a; 浏览器向DNS服务器发送查询请求&#xff0c;将域名解析为对应的IP地址。 3.CDN检查(如果有)&#…

C++ 算法学习之旅:从入门到精通的秘籍

在编程的浩瀚宇宙中&#xff0c;C 算法宛如璀璨的星辰&#xff0c;照亮我们前行的道路。作为一名 C 算法小白&#xff0c;或许你和我一样&#xff0c;怀揣着对算法的好奇与憧憬&#xff0c;却又在学习的道路上感到迷茫。别担心&#xff0c;今天我就和大家分享一下如何学习各种基…

计算机网络常识:缓存、长短连接 网络初探、URL、客户端与服务端、域名操作 tcp 三次握手 四次挥手

缓存&#xff1a; 缓存是对cpu&#xff0c;内存的一个节约&#xff1a;节约的是网络带宽资源 节约服务器的性能 资源的每次下载和请求都会造成服务器的一个压力 减少网络对资源拉取的延迟 这个就是浏览器缓存的一个好处 表示这个html页面的返回是不要缓存的 忽略缓存 需要每次…

软件逆向工程核心技术:脱壳原理与实战分析

目录 一、脱壳技术概述&#xff1a;从保护到还原的逆向之旅 1.1 脱壳技术的本质与核心价值 1.2 壳的分类与核心技术解析 1.3 学习路径&#xff1a;从压缩壳到加密壳的渐进式突破 二、脱壳三步法&#xff1a;系统化逆向工程框架 2.1 核心流程总览 2.2 实战案例&#xff1…