实验吧web-你真的会php吗

本文解析了一个CTF竞赛中的PHP题目,通过分析源码和构造特定输入,成功绕过检查并获取隐藏的flag。涉及PHP函数、字符串处理及回文数判断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:http://ctf5.shiyanbar.com/web/PHP/index.php
打开网页发现页面只有一个

have a fun!!

在这里插入图片描述
查看网页源码也没有任何东西
于是直接F12看headers
发现了在这里插入图片描述
跳转到http://ctf5.shiyanbar.com/web/PHP/6c525af4059b4fe7d8c33a.txt得到源码

<?php


$info = ""; 
$req = [];
$flag="xxxxxxxxxx";

ini_set("display_error", false); 
error_reporting(0); 


if(!isset($_POST['number'])){
   header("hint:6c525af4059b4fe7d8c33a.txt");

   die("have a fun!!"); 
}

foreach([$_POST] as $global_var) {                           //这一小段的意思就是将post上去的数据写进数组中
    foreach($global_var as $key => $value) { 
        $value = trim($value); 
        is_string($value) && $req[$key] = addslashes($value); 
    } 
} 


function is_palindrome_number($number) {           //判断传入的数据是否为回文数
    $number = strval($number); 
    $i = 0; 
    $j = strlen($number) - 1; 
    while($i < $j) { 
        if($number[$i] !== $number[$j]) { 
            return false; 
        } 
        $i++; 
        $j--; 
    } 
    return true; 
} 


if(is_numeric($_REQUEST['number'])){                            //number不能为整数
    
   $info="sorry, you cann't input a number!";

}elseif($req['number']!=strval(intval($req['number']))){                  //intval 将number转换为整数

     $info = "number must be equal to it's integer!! ";               //  原来的number和intval的number要相等  

}else{

     $value1 = intval($req["number"]);                           //将number转换为整数
     $value2 = intval(strrev($req["number"]));                   //将number反序   例如123化为321

     if($value1!=$value2){                 //为回文数
          $info="no, this is not a palindrome number!";
     }else{
          
          if(is_palindrome_number($req["number"])){            // 不是回文数
              $info = "nice! {$value1} is a palindrome number!"; 
          }else{
             $info=$flag;
          }
     }

}

echo $info;

直接构造number=0.000%00 post即可
%00当遇到is_number函数是会截断,0.000整数为0,反转后为000.0也等于0,故相等

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值