Метод __debugInfo
Метод __debugInfo
вызывается при выводе информации об объекте функциями
var_dump
и print_r
. Он должен возвращать массив с свойствами,
которые нужно отобразить. Это позволяет скрыть конфиденциальные данные
или добавить дополнительную отладочную информацию.
Синтаксис
public function __debugInfo(): array
Пример
Скрываем конфиденциальные данные при дампе объекта:
<?php
class User {
private $password;
public $name;
public function __construct($name, $password) {
$this->name = $name;
$this->password = $password;
}
public function __debugInfo() {
return [
'name' => $this->name,
'password' => '******'
];
}
}
$user = new User('John', 'secret123');
var_dump($user);
?>
Результат выполнения кода:
object(User)#1 (2) {
["name"]=> string(4) "John"
["password"]=> string(6) "******"
}
Пример
Добавляем дополнительную отладочную информацию:
<?php
class Product {
public $id;
public $price;
public function __construct($id, $price) {
$this->id = $id;
$this->price = $price;
}
public function __debugInfo() {
return [
'id' => $this->id,
'price' => $this->price,
'price_with_tax' => $this->price * 1.2
];
}
}
$product = new Product(101, 100);
var_dump($product);
?>
Результат выполнения кода:
object(Product)#1 (3) {
["id"]=> int(101)
["price"]=> int(100)
["price_with_tax"]=> float(120)
}
Пример
Фильтруем свойства для отображения:
<?php
class Config {
private $dbHost = 'localhost';
private $dbUser = 'admin';
private $cacheEnabled = true;
public function __debugInfo() {
return [
'cacheEnabled' => $this->cacheEnabled
];
}
}
$config = new Config();
print_r($config);
?>
Результат выполнения кода:
Config Object (
[cacheEnabled] => 1
)