攻防世界: simple_php

攻防世界: simple_php

  1. 访问网页,可以看到源码部分如下
php 复制代码
<?php
show_source(__FILE__);
include("config.php");
$a=@$_GET['a'];
$b=@$_GET['b'];
if($a==0 and $a){
    echo $flag1;
}
if(is_numeric($b)){
    exit();
}
if($b>1234){
    echo $flag2;
}
?>

这里可以简单了解下php相关的知识:


松散比较 (==) 的类型转换

当字符串与数字使用 == 比较时,PHP会尝试将字符串转换为数字

  • "0" == 0true (字符串 "0" 转为数字 0

到布尔值的隐式转换 (if($a))

ifandor 等布尔上下文中,值会被自动转换为 truefalse。这里我的第一想法是让a='0',这样在比较相等的时候是相等的,但是非空字符串为true.


is_numeric() 函数的行为

它判断一个变量是否是数字或数字字符串,但比较严格:

  • 返回 true1234"1234""-123.4""1e4""0x4d2"(十六进制)
  • 返回 false"1234abc""1234 "(尾部有空格)、"abc"NULL

字符串与数字的 > 比较

当字符串与数字进行大小比较时,PHP的行为是:

  1. 尝试将整个字符串转换为数字。
  2. 转换规则:从左到右读取,直到遇到第一个非数字字符(小数点除外)为止,将读取到的数字部分作为转换结果。
  3. 如果字符串不是以数字开头 ,则转换结果为 0

  1. 构造数据,根据前面的规则,我构造了下面的数据

a='0' (实际上是 a=0)

  • '0' 是一个字符串。在 $a==0 的松散比较中,PHP会将字符串 '0' 转换为数字 0,条件成立。
  • 同时,字符串 '0' 本身在 if($a) 的布尔判断中,它不为空且不是假值字符串 ,因此也为 true。(在PHP中,只有字符串 '''0' 会被认为是布尔假,但这里作为整体条件 $a 是存在的,所以为真。)
  • 因此满足 $a==0 and $a,触发 echo $flag1;

b=1235a

  • '1235a' 是一个以数字开头的字符串。is_numeric('1235a') 会返回 false,因此不会执行 exit()
  • $b>1234 的比较中,PHP会将字符串 '1235a' 强制转换为数字,取开头的 1235 进行比较,1235 > 1234 成立。
  • 因此触发 echo $flag2;

成功拿到数据!

相关推荐
Gary Studio15 小时前
安卓HAL编写
android
合天网安实验室18 小时前
记录一个免杀的php webshell demo
渗透测试·php·webshell·免杀
_李小白18 小时前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
AnalogElectronic18 小时前
linux 测试网络和端口是否连通的命令详解
linux·网络·php
jinanwuhuaguo19 小时前
OpenClaw工程解剖——RAG、向量织构与“记忆宫殿”的索引拓扑学(第十三篇)
android·开发语言·人工智能·kotlin·拓扑学·openclaw
跨境数据猎手20 小时前
跨境独立站系统技术拆解(附带源码)
服务器·前端·php
淘矿人21 小时前
从0到1:用Claude启动你的第一个项目
开发语言·人工智能·git·python·github·php·pygame
小怪吴吴21 小时前
idea 开发Android
android·java·intellij-idea
xiaoyan20151 天前
2026爆肝!Flutter3.41纯手撸微信聊天APP原生应用
android·flutter·dart
带娃的IT创业者1 天前
深度解析:从零构建高性能 LLM API 中转网关与成本优化实战
开发语言·gpt·llm·php·高性能·成本优化·api网关