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

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

js复制代码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

js复制代码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

js复制代码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 漏洞利用

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

1.条件竞争漏洞2.生成用户session3.并发使用优惠卷4.购买C8商品结束

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

0x01 获取用户session

image.png

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

js

复制代码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

题外话

网络安全行业特点

1、就业薪资非常高,涨薪快 2022年猎聘网发布网络安全行业就业薪资行业最高人均33.77万!

img

2、人才缺口大,就业机会多

2019年9月18日《中华人民共和国中央人民政府》官方网站发表:我国网络空间安全人才 需求140万人,而全国各大学校每年培养的人员不到1.5W人。猎聘网《2021年上半年网络安全报告》预测2027年网安人才需求300W,现在从事网络安全行业的从业人员只有10W人。
img

行业发展空间大,岗位非常多

网络安全行业产业以来,随即新增加了几十个网络安全行业岗位︰网络安全专家、网络安全分析师、安全咨询师、网络安全工程师、安全架构师、安全运维工程师、渗透工程师、信息安全管理员、数据安全工程师、网络安全运营工程师、网络安全应急响应工程师、数据鉴定师、网络安全产品经理、网络安全服务工程师、网络安全培训师、网络安全审计员、威胁情报分析工程师、灾难恢复专业人员、实战攻防专业人员…

职业增值潜力大

网络安全专业具有很强的技术特性,尤其是掌握工作中的核心网络架构、安全技术,在职业发展上具有不可替代的竞争优势。

随着个人能力的不断提升,所从事工作的职业价值也会随着自身经验的丰富以及项目运作的成熟,升值空间一路看涨,这也是为什么受大家欢迎的主要原因。

从某种程度来讲,在网络安全领域,跟医生职业一样,越老越吃香,因为技术愈加成熟,自然工作会受到重视,升职加薪则是水到渠成之事。

关于网络安全学习指南

学习网络安全技术的方法无非三种:

第一种是报网络安全专业,现在叫网络空间安全专业,主要专业课程:程序设计、计算机组成原理原理、数据结构、操作系统原理、数据库系统、 计算机网络、人工智能、自然语言处理、社会计算、网络安全法律法规、网络安全、内容安全、数字取证、机器学习,多媒体技术,信息检索、舆情分析等。

第二种是自学,就是在网上找资源、找教程,或者是想办法认识一-些大佬,抱紧大腿,不过这种方法很耗时间,而且学习没有规划,可能很长一段时间感觉自己没有进步,容易劝退。

第三种就是去找培训。

image.png

接下来,我会教你零基础入门快速入门上手网络安全。

网络安全入门到底是先学编程还是先学计算机基础?这是一个争议比较大的问题,有的人会建议先学编程,而有的人会建议先学计算机基础,其实这都是要学的。而且这些对学习网络安全来说非常重要。但是对于完全零基础的人来说又或者急于转行的人来说,学习编程或者计算机基础对他们来说都有一定的难度,并且花费时间太长。

第一阶段:基础准备 4周~6周

这个阶段是所有准备进入安全行业必学的部分,俗话说:基础不劳,地动山摇
image.png

第二阶段:web渗透

学习基础 时间:1周 ~ 2周:

① 了解基本概念:(SQL注入、XSS、上传、CSRF、一句话木马、等)为之后的WEB渗透测试打下基础。
② 查看一些论坛的一些Web渗透,学一学案例的思路,每一个站点都不一样,所以思路是主要的。
③ 学会提问的艺术,如果遇到不懂得要善于提问。
image.png

配置渗透环境 时间:3周 ~ 4周:

① 了解渗透测试常用的工具,例如(AWVS、SQLMAP、NMAP、BURP、中国菜刀等)。
② 下载这些工具无后门版本并且安装到计算机上。
③ 了解这些工具的使用场景,懂得基本的使用,推荐在Google上查找。

渗透实战操作 时间:约6周:

① 在网上搜索渗透实战案例,深入了解SQL注入、文件上传、解析漏洞等在实战中的使用。
② 自己搭建漏洞环境测试,推荐DWVA,SQLi-labs,Upload-labs,bWAPP。
③ 懂得渗透测试的阶段,每一个阶段需要做那些动作:例如PTES渗透测试执行标准。
④ 深入研究手工SQL注入,寻找绕过waf的方法,制作自己的脚本。
⑤ 研究文件上传的原理,如何进行截断、双重后缀欺骗(IIS、PHP)、解析漏洞利用(IIS、Nignix、Apache)等,参照:上传攻击框架。
⑥ 了解XSS形成原理和种类,在DWVA中进行实践,使用一个含有XSS漏洞的cms,安装安全狗等进行测试。
⑦ 了解一句话木马,并尝试编写过狗一句话。
⑧ 研究在Windows和Linux下的提升权限,Google关键词:提权
image.png
以上就是入门阶段

第三阶段:进阶

已经入门并且找到工作之后又该怎么进阶?详情看下图
image.png

给新手小白的入门建议:
新手入门学习最好还是从视频入手进行学习,视频的浅显易懂相比起晦涩的文字而言更容易吸收,这里我给大家准备了一套网络安全从入门到精通的视频学习资料包免费领取哦!

如果你对网络安全入门感兴趣,那么你需要的话可以在下方扫码领取!!

  • 12
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值