php的原生类

发布于:2025-07-14 ⋅ 阅读:(16) ⋅ 点赞:(0)

前言:累麻了!

反射类

反射类 ReflectionClass:ReflectionClass 类报告了一个类的有关信息。正如其名用于映射反射一个类的类!
new ReflectionClass('MyClass') 会创建一个 ReflectionClass 实例,代表 MyClass 这个类。

基础用法:

1.对象字符串的表示形式 

ReflectionClass::__toString  返回 ReflectionClass对象字符串的表示形式

<?php
class MyClass {
    public $name='rufeii';
    public function printName(){
        echo $this->name;
    }
}
$class = new ReflectionClass('MyClass');
echo $class;  //这里触发了__toString魔术方法
?>

展示了类的 定义位置、属性、方法 等信息。

Class [ class 类名 ] {
  文件位置 @@ 路径 行号范围
  - 常量 [数量] { 具体常量... }
  - 静态属性 [数量] { 具体静态属性... }
  - 静态方法 [数量] { 具体静态方法... }
  - 普通属性 [数量] { 具体属性... }
  - 方法 [数量] { 具体方法... }
}

2.获取类的名称

(new ReflectionClass("class?"))->getName() // 获取类名称

<?php
class MyClass {
    public $name='rufeii';
    public function printName(){
        echo $this->name;
    }
}
$class = new ReflectionClass('MyClass');
echo $class->getName(); // MyClass
?>
3.获取属性名称和属性值 
<?php
class MyClass {
    public $name='rufeii';
    public $age=19;
    public function printName(){
        echo $this->name;
    }
    public function printAge(){
        echo $this->age;
    }
}
$class = new ReflectionClass('MyClass');
$properties = $class->getProperties();

foreach ($properties as $property) {
    $name = $property->getName();
    $value = $property->getValue(new MyClass());
    echo "$name: $value\n";
}
?>

获取值用到了ReflectionProperty类的方法getValue(),是因为ReflectionClass::getProperty  #返回值是一个数组,是一个类所以还可以用来调用方法。

4.读取类的方法和参数
<?php
class MyClass {
    public $name='rufeii';
    public $age=19;
    public function printName($parameter1){
        echo $this->name;
        echo $parameter1;
    }
    public function printAge($parameter2){
        echo $this->age;
        echo $parameter2;
    }
}
$class = new ReflectionClass('MyClass');
$a=$class->getMethods();
foreach($a as $method)
{
        echo $method->getName()."(";
        $params=$method->getParameters();
        foreach($params as $param)
        {
            echo $param->getName().")<br>";
        }
}
?>

操作文件的类

目录遍历类

  1. DirectoryIterator      利用版本PHP5, PHP7, PHP8

  2. FilesystemIterator      利用版本,PHP 5且>= 5.3.0, PHP 7, PHP 8

  3. GlobIterator             PHP 5 且>= 5.3.0, PHP 7, PHP 8

1. DirectoryIterator

怎么去遍历文件目录,使用里面的__tostring()魔术方法

<?php
$dir=new DirectoryIterator("../");
foreach ($dir as $fileinfo) {
    echo $fileinfo."<br>";
}
?>
输出的第一个文件是.
第二个文件..
所以如果不用循环的话出来的就是.

当然也可以用glob://协议去作为一个伪文件系统访问接口去绕过open_basedir这个安全配置项(rce里面有个需要绕过open_basedir的)

<?php
$dir=new DirectoryIterator("glob:///*");
foreach($dir as $a){
    echo $a->__toString().' ';
}
?>
2.FilesystemIterator
<?php
$dir=new FilesystemIterator("../");
foreach ($dir as $fileinfo) {
    echo $fileinfo."<br>";
}
?>

与DirectoryIterator不同的是没有了前面两个没有的东西了(.和..),那么如果我们不用循环的话,直接输出的话,有可能也是可以获取敏感文件的!比如web99--web114(php特性篇)-CSDN博客 这里的web109!

那么这里也是可以用glob://协议的

3.GlobIterator

GlobIterator  继承于DirectoryIterator而且自带了glob,那么就可以直接使用linux的通配符

<?php

$dir=new GlobIterator("../*");
foreach($dir as $a){
    echo $a->__toString().' ';
}
?>

那么这里同样是没有.和..的,所以也可以利用直接输出$dir,说不定有用! 

文件读取的类

SplFileObject
<?php
$content=new SplFileObject('/flag');
foreach($content as $content){
    echo $content." ";
}
?>

总结

简单的水了一下,后续有机会在慢慢补吧!


网站公告

今日签到

点亮在社区的每一天
去签到