我有我的主 PHP 文件,只要有人访问我的服务器,它就会运行。它看起来像这样:
<?php
$config = require_once('./config/general.php');
define('ROOT', __DIR__.'/');
include(constant('ROOT').'libraries/log4php/Logger.php');
Logger::configure(constant('ROOT').'config/logging.xml');
$log = Logger::getLogger('main');
$requested_link = "http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
$route_url = str_replace($config['baseURL'], '', $requested_link);
$route_url = $route_url == '' ? '/' : $route_url;
define('ROUTE', $route_url);
require_once 'routeme.php';
routeme.php
找到处理请求的 url 的最佳“路由”类。它实例化该类,然后将请求信息传递给它创建的路由器类的实例以供处理。
所有路由器都扩展了一个基类:
<?php
namespace Blaze;
class Router {
private $log;
public function __construct() {
// The __CLASS__ constant holds the class name
$this->log = Logger::getLogger(__CLASS__);
}
public function routes (){
return array();
}
}
一个示例路由器:
<?php
namespace Blaze;
class GeneralRouter extends Router {
public function RootRoute ($url){
$log->info($url);
}
public function routes (){
return array(
'/' => 'RootRoute'
);
}
}
当我尝试运行应用程序时,它失败了,因为Router
该类没有Logger
从 log4php 中看到包含的类(当然,主文件中的日志语句运行良好)。我不能在每个路由器的基础上重新包含 Logger 类,因为 log4php 只允许它自己在应用程序中包含一次(可能是为了防止文件锁定冲突)。如何让路由器访问/查看 Logger 类?
解决方案必须是可扩展的,即稍后我将拥有更多类Router
,例如也需要访问 Logger 类的类。