访问

时间:2016-01-30 18:51:14

标签: php mysql oop mysqli scope

这让我发疯,我希望有人可以提供帮助。

我正在学习PHP,作为一个更大的项目的一部分来帮助我调试/记录问题,因为我发生了一个PHP错误记录类。

这是我的错误:

  

这是一个测试

     

我希望它有效!

     

成功!

     

注意:未定义的变量:第27行的/Applications/MAMP/htdocs/errorlog.php中的错误登录

     

致命错误:无法在第27行的/Applications/MAMP/htdocs/errorlog.php中访问空属性

所以我可以看到

第27行的错误包括:

$outputStringForSQL = $conn->escape_string($this->$errorLog);

我很难过。我不明白$errorLog是如何定义的,因为它已使用append()方法明确添加到两次,并使用returnLog()方法读取。属性$errorLog显然不是空的,因为returnLog()从中读取正常。我已经通过回复它来检查$this->errorLog是否为空。

我想也许我误解了范围,所以将$ erroLog设置为公开,仍然没有。

这是errorlog.php类'errorlog':

<?php
class errorlog{

protected $errorLog;

public function append($string){
  $this->errorLog = $this->errorLog . $string . "<br />";
}

public function returnLog() {
  echo $this->errorLog;
  return "Success!";
}

public function commit(){
  global $_mysqlUsername;
  global $_mysqlPassword;

  $servername = "localhost";
  $dbname = "my_DB";    //production

    // Create connection
  $conn = new mysqli($servername, 'root', 'root', $dbname);
    // Check connection
  if ($conn->connect_error) {
       die(error_log($conn->connect_error));
   }
   $outputStringForSQL = $conn->escape_string($this->$errorLog);
   $sql = "INSERT INTO `tblDebugLog` (`ID`, `dateTime`, `debugData`) VALUES (NULL, CURRENT_TIMESTAMP, '$outputStringForSQL');";
   if ($conn->query($sql) !== TRUE) {
     echo("Error: " . $sql . "<br>" . $conn->error);
   }
   $conn->close();
   return 'Success';
   }
}
?>

这是使用'errorlog'类的脚本:

<?php
   function __autoload($class){
      require "$class.php";
   }

   $myError = new errorlog;
   $myError->append('This is a test');
   $myError->append('I hope it worked!');
   echo $myError->returnLog();
   echo $myError->commit();
 ?>

任何人都可以对这个错误有所了解吗?

非常感谢。

1 个答案:

答案 0 :(得分:4)

$this->$errorLog替换为$this->errorLog