php的原生类

前言:累麻了!

反射类

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

基础用法:

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

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

php 复制代码
<?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 复制代码
<?php
class MyClass {
    public $name='rufeii';
    public function printName(){
        echo $this->name;
    }
}
$class = new ReflectionClass('MyClass');
echo $class->getName(); // MyClass
?>
3.获取属性名称和属性值
php 复制代码
<?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 复制代码
<?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 复制代码
<?php
$dir=new DirectoryIterator("../");
foreach ($dir as $fileinfo) {
    echo $fileinfo."<br>";
}
?>
输出的第一个文件是.
第二个文件..
所以如果不用循环的话出来的就是.

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

php 复制代码
<?php
$dir=new DirectoryIterator("glob:///*");
foreach($dir as $a){
    echo $a->__toString().' ';
}
?>
2.FilesystemIterator
php 复制代码
<?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 复制代码
<?php

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

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

文件读取的类

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

总结

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

相关推荐
catchadmin5 小时前
PHP 现在可以零成本构建原生 iOS 和 Android 应用 NativePHP for Mobile v3 发布
android·ios·php
子木鑫6 小时前
[SUCTF 2019] CheckIn1 — 利用 .user.ini 与图片马构造 PHP 后门并绕过上传检测
android·开发语言·安全·php
JSON_L6 小时前
使用 SQLite 创建数据库和表
数据库·sqlite·php
qinyia6 小时前
如何在服务器上查看网络连接数并进行综合分析
linux·运维·服务器·开发语言·人工智能·php
Big Cole6 小时前
PHP 面试:MySQL 核心问题之索引与优化
mysql·面试·php
子木鑫7 小时前
[SUCTF2019 & GXYCTF2019] 文件上传绕过实战:图片马 + .user.ini / .htaccess 构造 PHP 后门
android·开发语言·安全·php
CHU7290357 小时前
探索一番赏盲盒小程序:解锁多元互动体验新场景
小程序·php
m0_738120727 小时前
内网横向——记录某三层网络渗透及综合渗透(socks代理隧道搭建,nacos未授权,redis上传Webshell)
网络·安全·web安全·ssh·php
Big Cole7 小时前
PHP面试题(Redis核心知识篇)
开发语言·redis·php
JaguarJack7 小时前
Laravel AI SDK 在 Laracon India 2026 首次亮相
后端·php·laravel