Méthode __call
La méthode __call est une méthode magique en PHP qui est appelée automatiquement lors d'une tentative d'accès à une méthode de classe inexistante ou inaccessible. Son premier paramètre est le nom de la méthode appelée, le second - un tableau d'arguments.
Syntaxe
public function __call(string $name, array $arguments) {
// implémentation
}
Exemple
Créons une classe avec une méthode __call qui interceptera tous les appels aux méthodes inexistantes :
<?php
class Test {
public function __call($name, $args) {
echo "Méthode appelée : " . $name . "\n";
echo "Arguments : ";
print_r($args);
}
}
$test = new Test();
$test->nonExistentMethod('a', 'b', 123);
?>
Résultat de l'exécution du code :
Méthode appelée : nonExistentMethod
Arguments : ['a', 'b', 123]
Exemple
Implémentons un simple délégateur de méthodes à l'aide de __call :
<?php
class Calculator {
public function add($a, $b) {
return $a + $b;
}
}
class Math {
private $calculator;
public function __construct() {
$this->calculator = new Calculator();
}
public function __call($name, $args) {
if (method_exists($this->calculator, $name)) {
return call_user_func_array(
[$this->calculator, $name],
$args
);
}
throw new Exception("Méthode $name non trouvée");
}
}
$math = new Math();
echo $math->add(2, 3);
?>
Résultat de l'exécution du code :
5
Voir aussi
-
la méthode
__callStatic,
qui intercepte les appels aux méthodes statiques -
la méthode
__get,
qui intercepte les accès aux propriétés inexistantes