《CTF特训营》web部分读书笔记(六)条件竞争

本文是《CTF特训营》web部分关于条件竞争的读书笔记,介绍了条件竞争的概念,即在无锁或同步互斥的情况下,多线程或进程导致的输出不一致性问题。通过分析一般代码逻辑中的条件竞争示例以及数据库查询未加锁的情况,阐述了如何测试和识别这类问题。
摘要由CSDN通过智能技术生成

前言

继续阅读《CTF特训营》web部分
本节是条件竞争

1、简介

条件竞争(Race Condition)

  • 多个线程或进程在读写一个共享数据时
  • 由于没有锁或同步互斥管理
  • 导致输出不一致的问题

2、问题分析与测试

一般代码逻辑引发的条件竞争

例子
在这里插入图片描述
多用户访问时可能出现情况如下
在这里插入图片描述
测试方法

  • 用burp的intruder模块
  • 截取数据包后,设置访问次数payloads为1000,并发线程数80,看结果
数据库查询语句未加锁

在这里插入图片描述

select加锁的方式

select ..
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值