我正在尝试重写我的PDO MySQL类,它使用了一种依赖注入的形式。关于PHP OOP范围的困惑
下面是它的连接:
public function __construct($dsn, $username, $password)
{
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_STATEMENT_CLASS => array("EPDOStatement\EPDOStatement", array($this)),
PDO::ATTR_EMULATE_PREPARES => false, // allows LIMIT placeholders
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
];
parent::__construct($dsn, $username, $password, $options);
}
然后它被称为是这样的:
$dbl = new db_mysql("mysql:host=".$db_conf['host'].";dbname=".$db_conf['database'],$db_conf['username'],$db_conf['password']);
现在,命名为 “核心”,它有这样的__construct另一个类中:
class core
{
public $database;
function __construct($database)
{
$this->database = $database;
}
public static function config($key)
{
if (empty(self::$config))
{
// get config
$get_config = $this->database->select("config", '`data_key`, `data_value`');
$fetch_config = $get_config->fetch_all();
foreach ($fetch_config as $config_set)
{
self::$config[$config_set['data_key']] = $config_set['data_value'];
}
}
// return the requested key with the value in place
return self::$config[$key];
}
}
这就是所谓的:
$core = new core($dbl);
所以它需要数据库连接,并将其分配给在核心类中设置为“public”的$数据库。问题是,当我打电话的配置功能,我得到这个错误:
PHP Fatal error: Uncaught Error: Using $this when not in object context
它提到的错误来自行
"$this->database->select" inside the "config"
功能。
如何调用配置功能? –
你的缩进是怎么回事?这使它很难阅读。 –