php7过滤,PHP7过滤unserialize()

PHP7引入了过滤 unserialize()函数以在反序列化不受信任的数据对象时提供更好的安全性。它可以防止可能的代码注入,使开发人员能够使用序列化白名单类。

示例

class MyClass1 {

public $obj1prop;

}

class MyClass2 {

public $obj2prop;

}

$obj1 = new MyClass1();

$obj1->obj1prop = 1;

$obj2 = new MyClass2();

$obj2->obj2prop = 2;

$serializedObj1 = serialize($obj1);

$serializedObj2 = serialize($obj2);

// default behaviour that accepts all classes

// second argument can be ommited.

// if allowed_classes is passed as false, unserialize converts all objects into __PHP_Incomplete_Class object

$data = unserialize($serializedObj1 , ["allowed_classes" => true]);

// converts all objects into __PHP_Incomplete_Class object except those of MyClass1 and MyClass2

$data2 = unserialize($serializedObj2 , ["allowed_classes" => ["MyClass1", "MyClass2"]]);

print($data->obj1prop);

print("
");

print($data2->obj2prop);

?>

这将在浏览器产生以下输出 -

1

2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值