news 2026/6/25 0:26:54

攻防世界: simple_php

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
攻防世界: simple_php

攻防世界: simple_php

  1. 访问网页,可以看到源码部分如下
<?phpshow_source(__FILE__);include("config.php");$a=@$_GET['a'];$b=@$_GET['b'];if($a==0and$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;

成功拿到数据!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 20:19:40

3步搞定!EdgeRemover终极指南:让顽固的Edge浏览器彻底消失

3步搞定&#xff01;EdgeRemover终极指南&#xff1a;让顽固的Edge浏览器彻底消失 【免费下载链接】EdgeRemover PowerShell script to remove Microsoft Edge in a non-forceful manner. 项目地址: https://gitcode.com/gh_mirrors/ed/EdgeRemover 你是不是也遇到过这样…

作者头像 李华
网站建设 2026/6/20 10:52:28

AI智能证件照制作工坊冷启动优化:快速响应部署解决方案

AI智能证件照制作工坊冷启动优化&#xff1a;快速响应部署解决方案 1. 引言 1.1 业务场景描述 在数字化办公与在线身份认证日益普及的今天&#xff0c;用户对高质量、标准化证件照的需求持续增长。无论是求职简历、考试报名、电子政务还是社交平台实名认证&#xff0c;传统照…

作者头像 李华
网站建设 2026/6/18 23:33:29

OpenCore Configurator完全指南:5分钟掌握黑苹果终极配置方案

OpenCore Configurator完全指南&#xff1a;5分钟掌握黑苹果终极配置方案 【免费下载链接】OpenCore-Configurator A configurator for the OpenCore Bootloader 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Configurator 想要在普通PC上完美运行macOS系统吗…

作者头像 李华
网站建设 2026/6/23 18:15:33

智能客服实战:用Fun-ASR快速搭建多语言语音系统

智能客服实战&#xff1a;用Fun-ASR快速搭建多语言语音系统 1. 背景与需求分析 随着全球化业务的不断扩展&#xff0c;企业对跨语言沟通能力的需求日益增长。在智能客服、远程会议、在线教育等场景中&#xff0c;用户可能使用中文、英文、粤语、日文、韩文等多种语言进行交流…

作者头像 李华