2

我有我的主 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 类的类。

4

1 回答 1

1

在您的Router类中,导入Logger 类:

<?php

namespace Blaze;

use Logger;

class Router{
    public function __construct(){
        $this->log = Logger::getLogger(__CLASS__);
    }
}

如果您不导入 Logger,当您尝试调用它时,PHP 会尝试检索同一命名空间中的 Logger 类:

Blaze\Logger

如果你不想导入它,你可以这样做:

$this->log = \Logger::getLogger(__CLASS__);

然后在你的GeneralRouter

public function RootRoute($url){
    $this->log->info($url);
}
于 2017-05-12T18:09:58.103 回答