PHP MVC框架核心类

巴扎黑
巴扎黑asal
2016-11-08 09:48:351131semak imbas

PHP MVC框架核心类 
现在我们举几个核心框架的例子演示:在framework/core下建立一个Framework.class.php的文件。写入以下代码: 

// framework/core/Framework.class.php 
class Framework { 
   public static function run() { 
       echo "run()"; 
   } 
兄弟连教育www.lampbrother.net在这个演示中创建了一个静态方法run(),现在让我们通过入口文件index.php测试一下: 

require "framework/core/Framework.class.php"; 
Framework::run(); 
你可以在你的浏览器里访问index.php看到结果。通常这个静态方法被命名为run()或者bootstrap()。在这个方法中,我们要做3件最主要的事情: 

class Framework { 
   public static function run() { 
//        echo "run()"; 
       self::init(); 
       self::autoload(); 
       self::dispatch(); 
   } 
   private static function init() { 
   } 
   private static function autoload() { 
   } 
   private static function dispatch() { 
   } 

初始化 
init()方法: 

// Initialization 

private static function init() { 

    // Define path constants 

    define("DS", DIRECTORY_SEPARATOR); 

    define("ROOT", getcwd() . DS); 

    define("APP_PATH", ROOT . 'application' . DS); 

    define("FRAMEWORK_PATH", ROOT . "framework" . DS); 

    define("PUBLIC_PATH", ROOT . "public" . DS); 

    define("CONFIG_PATH", APP_PATH . "config" . DS); 

    define("CONTROLLER_PATH", APP_PATH . "controllers" . DS); 

    define("MODEL_PATH", APP_PATH . "models" . DS); 

    define("VIEW_PATH", APP_PATH . "views" . DS); 

    define("CORE_PATH", FRAMEWORK_PATH . "core" . DS); 

    define('DB_PATH', FRAMEWORK_PATH . "database" . DS); 

    define("LIB_PATH", FRAMEWORK_PATH . "libraries" . DS); 

    define("HELPER_PATH", FRAMEWORK_PATH . "helpers" . DS); 

    define("UPLOAD_PATH", PUBLIC_PATH . "uploads" . DS); 

    // Define platform, controller, action, for example: 

    // index.php?p=admin&c=Goods&a=add 

    define("PLATFORM", isset($_REQUEST['p']) ? $_REQUEST['p'] : 'home'); 

    define("CONTROLLER", isset($_REQUEST['c']) ? $_REQUEST['c'] : 'Index'); 

    define("ACTION", isset($_REQUEST['a']) ? $_REQUEST['a'] : 'index'); 

    define("CURR_CONTROLLER_PATH", CONTROLLER_PATH . PLATFORM . DS); 

    define("CURR_VIEW_PATH", VIEW_PATH . PLATFORM . DS); 

    // Load core classes 

    require CORE_PATH . "Controller.class.php"; 

    require CORE_PATH . "Loader.class.php"; 

    require DB_PATH . "Mysql.class.php"; 

    require CORE_PATH . "Model.class.php"; 


    // Load configuration file 
    $GLOBALS['config'] = include CONFIG_PATH . "config.php"; 
    // Start session 
    session_start(); 

在注释中你可以看到每一步的目的。 

自动加载 
在项目中,我们不想在脚本中想使用一个类的时候手动的去include或者require加载,这就是为什么PHP MVC框架都有自动加载的功能。例如,在symfony中,如果你想要加载lib下的类,它将会被自动引入。很神奇是吧?现在让我们在自己的框架中加入自动加载的功能。 

这里我们要用的PHP中的自带函数spl_autoload_register: 

// Autoloading 

private static function autoload(){ 

    spl_autoload_register(array(__CLASS__,'load')); 


// Define a custom load method 
private static function load($classname){ 

    // Here simply autoload app’s controller and model classes 

    if (substr($classname, -10) == "Controller"){ 

        // Controller 

        require_once CURR_CONTROLLER_PATH . "$classname.class.php"; 

    } elseif (substr($classname, -5) == "Model"){ 

        // Model 

        require_once  MODEL_PATH . "$classname.class.php"; 
    } 

每一个框架都有自己的命名规则,我们的也不例外。对于一个控制器类,它需要被命名成类似xxxController.class.php,对于一个模型类,需要被命名成xxModel.class.php。为什么在使用一个框架的时候你需要遵守它的命名规则呢?自动加载就是一条原因。 

路由/分发 
// Routing and dispatching 

private static function dispatch(){ 

    // Instantiate the controller class and call its action method 

    $controller_name = CONTROLLER . "Controller"; 

    $action_name = ACTION . "Action"; 

    $controller = new $controller_name; 

    $controller->$action_name(); 


在这步中,index.php将会分发请求到对应的Controller::Aciton()方法中。 

基础Controller类 
通常在框架的核心类中都有一个基础的控制器。在symfony中,被称为sfAction;在iOS中,被称为UIViewController。在这里我们命名为Controller,在framework/core下建立Controller.class.php 
// Base Controller 
class Controller{ 
    // Base Controller has a property called $loader, it is an instance of Loader class(introduced later) 
    protected $loader; 
    public function __construct(){ 
        $this->loader = new Loader(); 
    } 
    public function redirect($url,$message,$wait = 0){ 
        if ($wait == 0){ 
            header("Location:$url"); 
        } else { 
            include CURR_VIEW_PATH . "message.html"; 
        } 
        exit; 
    } 

基础控制器有一个变量$loader,它是Loader类的实例化(后面介绍)。准确的说,$this->loader是一个变量指向了被实例化的Load类。在这里我不过多的讨论,但是这的确是一个非常关键的概念。我遇到过一些PHP开发者相信在这个语句之后: 
$this->loader = new Loader(); 
$this->load是一个对象。不,它只是一个引用。这是从Java中开始使用的,在Java之前,在C++和Objective C中被称为指针。引用是个封装的指针类型。比如,在iOS(O-C)中,我们创建了一个对象: 
UIButton *btn = [UIButton alloc] init]; 
加载类 
在framework.class.php中,我们已经封装好了应用的控制器和模型的自动加载。但是如何自动加载在framework目录中的类呢?现在我们可以新建一个Loader类,它会加载framework目录中的类和函数。当我们加载framework类时,只需要调用这个Loader类中的方法即可。 
class Loader{ 
    // Load library classes 
    public function library($lib){ 
        include LIB_PATH . "$lib.class.php"; 
    } 
    // loader helper functions. Naming conversion is xxx_helper.php; 
    public function helper($helper){ 
        include HELPER_PATH . "{$helper}_helper.php"; 
    } 
}

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:lnmp环境搭建Artikel seterusnya:PHP判断PC浏览器与手机浏览器的方法