攻防世界: 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;

成功拿到数据!

相关推荐
天宁4 小时前
Workerman + ThinkPHP 8 结合使用
php·thinkphp
Doro再努力6 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Daniel李华6 小时前
echarts使用案例
android·javascript·echarts
做人不要太理性7 小时前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我123458 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
qq_353737548 小时前
网站评分系统API
php
huaweichenai8 小时前
中国工商银行支付对接
php
朗迹 - 张伟8 小时前
Tauri2 导出 Android 详细教程
android
搂着猫睡的小鱼鱼8 小时前
Ozon 商品页数据解析与提取 API
爬虫·php
lpruoyu9 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习