[CISCN 2019 初赛]Love Math详细理解(代码审计四)

本文详细介绍了PHP中的preg_match_all函数、正则表达式/m标志、in_array函数以及base_convert等数学函数的用法。通过示例展示了如何防止非法字符输入,并探讨了如何利用这些函数进行命令注入攻击,包括变量覆盖和getallheaders函数的使用。文章最后给出了两种解题思路,揭示了命令注入的绕过技巧。

[CISCN 2019 初赛]Love Math

扫盲:

1.preg_match_all()函数

<?php
$userinfo = "Name: <b>PHP</b> <br> Title: <b>Programming Language</b>";
preg_match_all ("/<b>(.*)<\/b>/U", $userinfo, $pat_array);
print_r($pat_array[0]);
?>

以第二个参数为匹配对象,第一个参数为正则表达式,然后将结果以数组的形式储存在第三个参数当中

2./m在正则表达式中的作用为:将模式视为多行,使用^和$表示任何一行都可以以正则表达式开始或结束

3.in_array():判断数组中是否存在指定的值

4.PHP base_convert() 函数:函数在任意进制之间转换数字:

/把八进制数转换为十六进制数:
<?php
$oct = "364";
echo base_convert($oct,8,16);
?>

题目:

<?php
error_reporting(0);
//听说你很喜欢数学,不知道你是否爱它胜过爱flag
if(!isset($_GET['c'])){
   
   
    show_source(__FILE__);
}else{
   
   
    //例子 c=20-1
    $content = $_GET['c'];
    if (strlen($content) >= 80) {
   
   
        die("太长了不会算");
    }
    $blacklist = [' ', '\t', 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Yn8rt

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值