Это мой класс базы данных:
<?php
// Database class
final class Database {
private static $instance = null;
public $db;
private function __construct() {
global $config;
global $app;
$config = (object) $config["database"];
try {
$dsn = sprintf("%s:hostname=%s;dbname=%s;", $config->driver, $config->host, $config->dbname);
$this->db = new PDO($dsn, $config->username, $config->password);
$this->db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$this->db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
} catch(PDOException $e) {
// stop app
// Redirect to /error/database
}
}
public static function getDb() {
if(Database::$instance == null) Database::$instance = new Database();
return Database::$instance->db;
}
}
Теперь, если соединение с базой данных не удается, я хотел бы перенаправить пользователя на /error/database
,
Тем не менее, он не перенаправляет. я пытался
header("Location: /error/database");
А также
$app->redirect("/error/database");
Я также попытался создать собственный обработчик ошибок (с $app->error(function() { ... });
и в улове $app->error
Однако это возвращает NULL
?
Это решение не работает для меня, может быть, потому что он использует SlimFramework 2, а я использую 3?
Исправил, я добавил Middelware
// add a middleware, check if we have a database connection
$app->add(function($req, $res, $next) use($app) {
if(Database::getDb() == null &&
!preg_match("/error/", $req->getUri())) {
return $res
->withStatus(500)
->withHeader("Location", $app
->getContainer()
->router
->pathFor("error-database"));
}
return $next($req, $res);
});
Других решений пока нет …