每当我尝试调用它时$this->dbc
,Is_Staff
都会返回一条错误消息:
Fatal error: Using $this when not in object context
我不太确定为什么要这么做。我试过将$ dbc设置为全局,但这似乎无济于事。
Class BoardDatabase {
public $dbhost = "localhost"; // Host
public $dbuser = "root"; // Username
public $dbpass = ""; // Password
public $dbname = "NecBoard"; // Database
public function __construct($dbhost, $dbuser, $dbpass, $dbname) {
$this->dbc = new mysqli($this->dbhost, $this->dbuser, $this->dbpass, $this->dbname) or die("Couldnt connect to the database! " . mysqli_errno);
if(!$this->dbc) {
die("Could not connect to database: " . $this->dbc->connect_errno());
}
}
public static function Is_Staff($type, $bool) {
if($type == "mod") {
if($bool == true) {
$IsStaff = $this->dbc->prepare("SELECT is_mod FROM users WHERE id = ?");
$IsStaff->bind_param("s", $_SESSION["id"]);
$IsStaff->execute();
$IsStaff->bind_result($is_mod);
$IsStaff->store_result();
if($IsStaff->num_rows >= 1) {
$IsStaff->fetch();
if($is_mod >= 1) {
return true;
} else {
return false;
}
}
} else {
return false;
}
}
}
}
问题
首先,当$dbc
变量BoardDatabase
甚至不是对象本身的属性时,您都将其作为对象的上下文进行访问。
其次,您不能$this
在静态上下文中使用来访问变量。
解决方案
$dbc
在顶部将变量声明为静态变量:
public static $dbc;
并在对象上下文中以这种方式访问它:
self::$dbc
这应该可以解决您的问题。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句