CTF-Web23(还爆破?这么多代码,告辞!)

知识点:

substr(string,start<,length>)从string 的start位置开始提取字符串
intval() 函数用于获取变量的整数值。可以进行进制转换

int intval ( mixed $var [, int $base = 10 ] )
base 为0则根据输入的进制格式进行转换

查看代码发现

代码要求get传入的token经过md5加密后,第1位===第14位===第17位并且(第1位+第14位+第17位)/第1位===第31位

 可以通过脚本代码运行找出合适的token值

<?php

for($i=0;$i<1000;$i++){
    if(isset($i)){
        $token = md5($i);
        if(substr($token, 1,1)===substr($token, 14,1) && substr($token, 14,1) ===substr($token, 17,1)){
            if((intval(substr($token, 1,1))+intval(substr($token, 14,1))+substr($token, 17,1))/substr($token, 1,1)===intval(substr($token, 31,1))){
                echo $i;
            }
        }
    }else{
        continue;

    }

}
?>

 发现输出位422,则token为422,传入获得flag

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值