Использование общих геттеров и сеттеров с php

Существуют тысячи примеров php __get и __set, к сожалению, никто не говорит вам, как их использовать.

Итак, мой вопрос: как мне на самом деле вызвать метод __get и __set из класса и при использовании объекта.

Пример кода:

class User{
public $id, $usename, $password;

public function __construct($id, $username) {
         //SET AND GET USERNAME
}

public function __get($property) {
    if (property_exists($this, $property)) {
        return $this->$property;
    }
}

public function __set($property, $value) {
    if (property_exists($this, $property)) {
        $this->$property = $value;
    }

    return $this;
}
}

$user = new User(1, 'Bastest');
// echo GET THE VALUE;

Как мне установить значения в конструкторе и как получить значение в // echo GET THE VALUE;


person inControl    schedule 25.09.2013    source источник
comment
Я не уверен, что вы прочитали, но предлагаю вам прочитать официальная справочная страница - очевидно, вы не понимаете, для каких целей нужны __set() и __get().   -  person Alma Do    schedule 25.09.2013
comment
в вашем установщике $this-›$property = $value; должно быть $this-›$property = $value[0];   -  person Joe Love    schedule 11.10.2017


Ответы (1)


Эта функция называется overloading в PHP. Как указано в документации, методы __get или __set будут вызываться, если вы пытаетесь получить доступ к несуществующим или недоступным свойствам. Проблема в вашем коде заключается в том, что свойства, к которым вы обращаетесь, существуют и доступны. Вот почему __get/__set вызываться не будет.

Проверьте этот пример:

class Test {

    protected $foo;

    public $data;

    public function __get($property) {
        var_dump(__METHOD__);
        if (property_exists($this, $property)) {
            return $this->$property;
        }
    }

    public function __set($property, $value) {
        var_dump(__METHOD__);
        if (property_exists($this, $property)) {
            $this->$property = $value;
        }
    }
}

Тестовый код:

$a = new Test();

// property 'name' does not exists
$a->name = 'test'; // will trigger __set
$n = $a->name; // will trigger __get

// property 'foo' is protected - meaning not accessible
$a->foo = 'bar'; // will trigger __set
$a = $a->foo; // will trigger __get

// property 'data' is public
$a->data = '123'; // will not trigger __set
$d = $a->data; // will not trigger __get
person hek2mgl    schedule 25.09.2013
comment
Спасибо, я тоже так понял и попробовал. Проблема, конечно, заключалась в том, что общедоступные переменные в моем примере должны быть частными, включая это в ваш ответ, и я приму это. - person inControl; 25.09.2013
comment
@inControl Вы также можете явно вызвать $this->__set() или этот $this->__get(). Это интересно, если вы получаете доступ к защищенным свойствам внутри класса. - person hek2mgl; 25.09.2013