zoukankan      html  css  js  c++  java
  • PHP MVC框架核心类

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

    // framework/core/Framework.class.php

    class Framework {

       publicstatic function run() {

           echo"run()";

       }

    兄弟连教育在这个演示中创建了一个静态方法run(),现在让我们通过入口文件index.php测试一下:

    <?php

    require"framework/core/Framework.class.php";

    Framework::run();

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

    class Framework {

       publicstatic function run() {

    //        echo"run()";

          self::init();

           self::autoload();

          self::dispatch();

       }

       privatestatic function init() {

       }

       privatestatic function autoload() {

       }

       privatestatic function dispatch() {

       }

    }

    初始化

    init()方法:

    // Initialization

    private static function init() {

        // Definepath 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);

        // Defineplatform, 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);

        // Loadcore classes

        requireCORE_PATH . "Controller.class.php";

        requireCORE_PATH . "Loader.class.php";

        requireDB_PATH . "Mysql.class.php";

        requireCORE_PATH . "Model.class.php";

        // Loadconfiguration file

       $GLOBALS['config'] = include CONFIG_PATH . "config.php";

        // Startsession

       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){

        // Heresimply autoload app&rsquo;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

    <?php

    // Base Controller

    class Controller{

        // BaseController has a property called $loader, it is an instance of Loaderclass(introduced later)

        protected$loader;

        publicfunction __construct(){

           $this->loader = new Loader();

        }

        publicfunction 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++和ObjectiveC中被称为指针。引用是个封装的指针类型。比如,在iOS(O-C)中,我们创建了一个对象:

    UIButton *btn = [UIButton alloc] init];

    加载类

    在framework.class.php中,我们已经封装好了应用的控制器和模型的自动加载。但是如何自动加载在framework目录中的类呢?现在我们可以新建一个Loader类,它会加载framework目录中的类和函数。当我们加载framework类时,只需要调用这个Loader类中的方法即可。

    class Loader{

        // Loadlibrary classes

        publicfunction library($lib){

           include LIB_PATH . "$lib.class.php";

        }

        // loaderhelper functions. Naming conversion is xxx_helper.php;

        publicfunction helper($helper){

           include HELPER_PATH . "{$helper}_helper.php";

        }

    }

  • 相关阅读:
    使用AnsyncTask异步类从网络上下载图片
    fibonacci分治求法
    JavaScript
    JavaScript
    JavaScript
    JavaScript
    yarn安装vue后,报“文件名、目录名或卷标语法不正确。”
    VIM-Plug安装插件时,频繁更新失败,或报端口443被拒绝等
    Node.js Windows Binary二进制文件安装方法
    Linux常用命令
  • 原文地址:https://www.cnblogs.com/xdlltao/p/5969646.html
Copyright © 2011-2022 走看看