网络安全入门过程教程:条件竞争漏洞

image.png

1.前言

本次靶场来源于hack the box 的 Diogenes’ Rage 来过程展示条件竞争漏洞,帮助入门学习网络安全的同学了解更多渗透技能

2 什么是条件竞争漏洞

了解网络安全技能,必须得先知道这些手段是什么意思,才好下一步了解。条件竞争漏洞是一种服务器端的漏洞,由于服务器端在处理不同用户的请求时是并发进行的,开发者在进行代码开发时常常倾向于认为代码会以线性的方式执行,而且他们忽视了并行服务器会并发执行多个线程,这就会导致意想不到的结果。简而言之,就是并没有考虑线程同步。如果并发处理不当或相关操作逻辑顺序设计的不合理时,将会导致此类问题的发生。

举个例子

同一时间去完成一件事情导致系统数据出现错误。 比如说,某网站有抢购功能, 正常情况下,一个人只能抢购一次。当出现同一时间内同时点击了两次,那么就造成一个人抢购了2次。生成了2条订单。
请添加图片描述

3 漏洞的危害

  1. 数据不一致:由于多个线程同时访问共享数据,可能导致数据的不一致性。
  2. 资源耗尽:如果多个线程同时访问有限的资源,如数据库连接,可能会导致资源耗尽,影响系统的性能。
  3. 安全问题:条件竞争漏洞常常被黑客利用,导致拒绝服务攻击、恶意代码执行等安全问题。

4.实战过程

首先打开进入到靶场 Diogenes’ Rage,我们可以看到以下页面:

image.png

4.1 信息收集

从页面上我们可以看到信息有:人、自助贩卖机、按键、投币口、优惠价、猫

image.png

4.1.1 页面信息

表面上看重点在于自助贩卖机。 人和猫没啥用。尝试操作按键按不动,只有将优惠券移动到投币口才能点击。放入优惠券只有一美元的优惠券,看来我只能买1美元以下的东西。优惠价使用后无法继续使用,重置将删除掉用户信息。

image.png

因此收集到的信息有以下:

1.优惠价1美元,只能购买一美元以下的商品。 2.在贩卖机中,最突出的是C8,其他都是1美元以下的商品,唯独C8最特别。它应该是目标 3.优惠价使用后无法继续使用 4.充值将会删除原先数据

4.1.2 浏览器信息

在使用优惠价或购买东西时,会发现操作会在客户端中生成一个用户session。

image.png

因此收集到的信息有:

1.操作使用优惠价及购买商品时产生用户session

4.1.3 网络信息

查看网络信息中,总共有三个请求,分别是:添加余额、重置、获取商品。因此收到的信息有:

image.png

1.添加余额:POST /api/coupons/apply

POST /api/coupons/apply HTTP/1.1
Host: 159.65.60.16:30556
Content-Length: 25
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.5735.134 Safari/537.36
Content-Type: application/json
Accept: */*
Origin: http://159.65.60.16:30556
Referer: http://159.65.60.16:30556/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close

{"coupon_code":"HTB_100"}

2.重置:POST /api/reset

GET /api/reset HTTP/1.1
Host: 159.65.60.16:30556
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.5735.134 Safari/537.36
Accept: */*
Referer: http://159.65.60.16:30556/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: session=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InR5bGVyXzdkMjcyNzg5ZmQiLCJpYXQiOjE2ODcwNDQ5NjR9.WPpasZ7TWX50OwFrGQREvH9h6vAwBMsn_wf4S5IFNYs
If-None-Match: W/"21-oskZXGh0wEybs4twcoBZFzzY2RY"
Connection: close

3.下单:/api/purchase

POST /api/purchase HTTP/1.1
Host: 159.65.60.16:30556
Content-Length: 13
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.5735.134 Safari/537.36
Content-Type: application/json
Accept: */*
Origin: http://159.65.60.16:30556
Referer: http://159.65.60.16:30556/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: session=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InR5bGVyXzdkMjcyNzg5ZmQiLCJpYXQiOjE2ODcwNDQ5NjR9.WPpasZ7TWX50OwFrGQREvH9h6vAwBMsn_wf4S5IFNYs
Connection: close

{"item":"A1"}

请添加图片描述

5 漏洞分析

结合以上信息,我们得知这个网站和数据库有交互,可以保留sql注入。但总体发现,需要购买C8商品,需要钱,但目前只有1美元。使用sqlmap尝试查找发现并无sql注入。其他的注入工具也不起效。

观看页面可以分析,在使用优惠价是否存在条件竞争漏洞,因此可以尝试一下。

6 漏洞利用

经过收集到的信息,使用条件竞争漏洞。那么攻击流程就是:

graph TD
1.条件竞争漏洞 --> 2.生成用户session --> 3.并发使用优惠卷 --> 4.购买C8商品 --> 结束

根据以上流程,我们先生成用户session,但不能使用优惠价接口,因为它只能使用一次。

0x01 获取用户session

image.png

在响应体中可以看到设置了cookie(Set-Cookie),这个就是用户session

session=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InR5bGVyXzk5YmQwYzBlM2IiLCJpYXQiOjE2ODcwNDU3NDJ9.lXnIsSrHu88XgwfSLnweDtJksRygTbLzQMCj9NpwGkE

0x02 开始条件竞争

拿到用户session后,使用工具或者你自己写并发代码进行利用条件竞争漏洞。博主用的是burp suite工具的插件 turbo Intruder 找到apply接口进行请求,将第一步的session设置在使用优惠价接口 image.png 设置并发,一个优惠价是1美元,那么购买C8至少并发要有14次。那么可以自行根据网络情况调试并发数量,博主的并发数是30.

image.png

点击下方Attack 开始发送请求!可以发现,出现200的就是成功,说明条件竞争漏洞是成立的:

image.png

0x03 购买C8商品

在成功后,将第一步的session保存到下单接口并设置成cookie,重新发送,即可购买成功:

image.png

7 如何防范

为了防范条件竞争漏洞,可以采取以下措施:

  1. 使用安全的编程语言:避免使用不安全的编程语言,如C语言或C++语言,尽量使用更安全的编程语言,如Java、Python等。
  2. 加强输入验证:加强输入验证可以防止恶意用户通过输入恶意数据来攻击系统。
  3. 使用安全的函数:使用安全函数可以避免因为程序员拙劣的编程技巧导致的缓冲区溢出漏洞。
  4. 使用线程安全函数:线程安全函数可以避免因为多个并发执行流共享同一对象导致的条件竞争漏洞。

8 总结

经过实战相信各位入门的小伙伴对条件竞争漏洞有一定的了解了吧~ over

给大家的福利

零基础入门

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

同时每个成长路线对应的板块都有配套的视频提供:

在这里插入图片描述

因篇幅有限,仅展示部分资料

朋友们如果有需要全套《网络安全入门+进阶学习资源包》,可以扫描下方二维码免费领取(如遇扫码问题,可以在评论区留言领取哦)~

请添加图片描述

网络安全面试题

绿盟护网行动

还有大家最喜欢的黑客技术

网络安全源码合集+工具包

所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码免费领取(如遇扫码问题,可以在评论区留言领取哦)~

请添加图片描述

  • 20
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值