BUU21 [极客大挑战 2019]BuyFlag1

打开pay.php界面F12可以看见源代码

php 复制代码
<!--
	~~~post money and password~~~
if (isset($_POST['password'])) {
	$password = $_POST['password'];
	if (is_numeric($password)) {
		echo "password can't be number</br>";
	}elseif ($password == 404) {
		echo "Password Right!</br>";
	}
}
-->

然后用POST提交password=404asfdf&money=100000000

半天没动静,后来看网上才知道应该抓包修改Cookie的值,不然就不能认证为CUIT,这个在ATTENTION的第二行也有体现(所以总计是有三个条件)

这里将user的值从0改为1(0代表着false)

为了让password绕过数字验证,以下几种写法都可以:

404asdf(随便写) 404%20 404%00

然后就显示money的值太长了,有两种方法可以修改:
1.科学计数法

将money的值写为1e9 (注意这里要大于题目给的1e8)

但是为什么1e8不行呢?(明明可以转化啊)

2.数组绕过

因为提示的是字符串太长了,所以网上猜测可能采用strcmp()进行比大小,所以这里可以用数组绕过

strcmp():它会按照字节顺序对两个字符串进行比较,区分大小写。该函数常用于需要精确比较字符串内容的场景,比如验证用户输入的密码是否正确等

  • 返回值
    • 如果 $str1 小于 $str2,返回一个小于 0 的整数。
    • 如果 $str1 大于 $str2,返回一个大于 0 的整数。
    • 如果 $str1 等于 $str2,返回 0

将money写为money[]=0(随便一个数),strcmp()在遇见数组和数比大小的时候会直接返回0,也就是这个数和数组相等

拿到flag

相关推荐
SunnyDays10116 分钟前
Java 读写 Excel 公式:从基础到高级的实战总结
java·开发语言·excel
wb043072018 分钟前
Java 26
java·开发语言
白露与泡影11 分钟前
JVM GC调优实战:从线上频繁Full GC到RT降低80%的全过程
java·开发语言·jvm
范什么特西13 分钟前
Spring 动态代理 静态代理
java·后端·spring
醇氧14 分钟前
Spring 动态注册 Bean 深度解析:从源码到实践
java·后端·spring
樱桃花下的小猫14 分钟前
森林 — 开发者控制台指令与物品ID速查手册
服务器·森林·云鸢互联·零门槛一键搭建·新手友好无技术门槛要求·森林游戏服务器·森林低延迟稳定服务器
霞姐聊IT29 分钟前
SR-IOV、MR-IOV 与 SIOV:PCIe虚拟化技术的过去、现在与未来
linux·服务器·虚拟化·pcie
小村儿1 小时前
连载10-Sub-agents 深度解析:从源码理解 Claude Code 的分身术
前端·后端·ai编程
笨拙的老猴子1 小时前
[特殊字符] Java GC机制详解:G1、ZGC、Shenandoah全面解析与版本演进对比
java·开发语言
tedcloud1231 小时前
hello-agents部署教程:从零学习AI Agent开发
服务器·人工智能·学习·自动化·powerpoint