Класс PHP выдает ошибку неопределенной общедоступной переменной, которая объявлена

Я пишу класс PHP для Logger. Я объявил две общедоступные переменные $file_log и $file_log_error.

class Logger
{
    //constants declaration
    const FILE_BASE = '/log/comunio-uk-log-';

    // property declaration
    protected $file_log = '';
    protected $file_log_error = '';

    // Constructor
    function __construct() {
        $date = getdate();
        $file_log_name = self::FILE_BASE.$date["mday"]."-".$date["mon"]."-".$date["year"].".log";
        $file_log_error_name = self::FILE_BASE.$date["mday"]."-".$date["mon"]."-".$date["year"].".log.error";
        $this->file_log = $file_log_name;
        $this->file_log_error = $file_log_error_name;

        if (file_exists($this->file_log )) {
            echo "#OK for 'file_log' var: <br><pre>", print_r($this->file_log, true), "</pre><br><br>";
        } else {
            echo "#OK for 'file_log' var: <br><pre>", print_r($this->file_log, true), "</pre><br><br>";;
        }

        if (file_exists($this->file_log_error)) {
            echo "#ERROR for 'file_log_error' var: <br><pre>", print_r($this->$file_log_error, true), "</pre><br><br>";
        } else {
            echo "#ERROR for 'file_log_error' var: <br><pre>", print_r($this->$file_log_error, true), "</pre><br><br>";
        }
    }
}

Когда я создаю новый объект класса, вызывается конструктор, и я получаю следующую ошибку:

#OK for 'file_log': 
/log/comunio-uk-log-13-2-2016.log

#ERROR for 'file_log_error': 

Notice:  Undefined variable: file_log_error in C:\xampp5.6\htdocs\comuniazo-uk\api\bd\logger.php on line 28

Fatal error:  Cannot access empty property in C:\xampp5.6\htdocs\comuniazo-uk\api\bd\logger.php on line 28

Почему первая защищенная переменная $file_log распознается, а вторая, $file_log_error, нет?

Я уже пробовал объявлять переменные как общедоступные и частные. Тот же результат.


person daniegarcia254    schedule 13.02.2016    source источник


Ответы (1)


$file_log_error никогда не определяется. Заменять

print_r($this->$file_log_error, true)

с участием

print_r($this->file_log_error, true)

Если вы пишете

$varName = 'test';
$obj = new stdClass;
$obj->test = 'foo';
$obj->varName = 'bar';
echo $obj->$varName; // echo $obj->test gives 'foo', not 'bar'
person Jan Sverre    schedule 13.02.2016