PHP实现MVC开发: 一个大概的MVC

今日研究了下PHP
MVC结构,所以决定好写个大概的MVC,以待下有空再增长。
有关什么MVC结构,其实就是三独Model,Contraller,View单词的简称,,Model,主要任务就是把数据库或者其他文件系统的数量以
照我们要之点子读取出来。View,主要承担页面的,把数据以html的样式显得为用户。Controller,主要担负作业逻辑,根据用户之
Request进行呼吁的分红,比如说显示登陆界面,就待调用一个控制器userController的计loginAction来显示。
脚我们因此PHP来创造一个概括的MVC结构体系。
率先创建单点入口,即bootstrap文件index.php,作为整个MVC系统的绝无仅有入口。什么是单纯点入口为?所谓单点入口即是全体应用程序只来一样
个输入,所有的落实都由此是进口来转发。为什么要完成单点入口为?单点入口出几异常利益:第一、一些体系全局处理的变量,类,方法都足以在此地展开拍卖。
比如说你要是本着数据开展初步的过滤,你若效仿session处理,你如定义有全局变量,甚至你要登记一些对象要变量到注册器里面。第二、程序的架更加
清晰明了。当然好处还有很多的。:)

<?php 
include("core/ini.php"); 
initializer::initialize(); 
$router = loader::load("router"); 
dispatcher::dispatch($router);
?>

此文件就惟有来4词,我们现平词词来分析。

1 include(”core/ini.php”);

 

咱俩来拘禁core/ini.php

 

1 <?php
2 set_include_path(get_include_path() . PATH_SEPARATOR . "core/main"); 
3 //set_include_path — Sets the include_path configuration option 
4 function __autoload($object)
5 {
6  require_once("{$object}.php");
7 } 
8 ?>

 

夫文件首先设置了include_path,也就是咱们只要只要摸包含的文件,告诉系统于这个目录下搜寻。其实我们定义__autoload()方法,这个法是于PHP5增加的,就是当我们实例化一个函数的时节,如果按文件没有,就会自行去加载文件。官方的解说是:
Many developers writing object-oriented applications create one PHP
source file per-class definition.
One of the biggest annoyances is having to write a long list of needed
includes at the beginning of each script (one for each class).

In PHP 5, this is no longer necessary.
You may define an __autoload function which is automatically called
in
case you are trying to use a class/interface which hasn’t been defined
yet. By calling this function the
scripting engine is given a last chance to load the class before
PHP fails with an error.

接下去我们看下面一句

1 initializer::initialize();

 

立刻就是谈就是调整用initializer类的一个静态函数initialize,因为我们以ini.php,设置了include_path,以及定义了__autoload,所以程序会自动在core/main目录查找initializer.php.
initializer.php文件如下:

 1 <?php
 2  class initializer
 3  { 
 4     public static function initialize() 
 5     { 
 6         set_include_path(get_include_path().PATH_SEPARATOR . "core/main"); 
 7         set_include_path(get_include_path().PATH_SEPARATOR . "core/main/cache");
 8         set_include_path(get_include_path().PATH_SEPARATOR . "core/helpers"); 
 9         set_include_path(get_include_path().PATH_SEPARATOR . "core/libraries"); 
10         set_include_path(get_include_path().PATH_SEPARATOR . "app/controllers"); 
11         set_include_path(get_include_path().PATH_SEPARATOR."app/models"); 
12         set_include_path(get_include_path().PATH_SEPARATOR."app/views"); 
13         //include_once("core/config/config.php"); } }
14 ?> 

此函数很简单,就惟有定义了一个静态函数,initialize函数,这个函数就是装include_path,这样,以后要带有文件,或者__autoload,就会去这些目录下寻找。

OK,我们延续,看第三句

1 $router = loader::load(”router”);

 

立刻句话也非常简单,就是加载loader函数的静态函数load,下面我们来loader.php

 1 <?php 
 2     class loader 
 3         {
 4          private static $loaded = array();
 5          public static function load($object)
 6         { 
 7         $valid = array( "library", "view", "model", "helper", "router", "config", "hook", "cache", "db"); 
 8         if (!in_array($object,$valid))
 9         { 
10           throw new Exception("Not a valid object '{$object}' to load");
11         } 
12         if (empty(self::$loaded[$object]))
13         { 
14             self::$loaded[$object]= new $object();
15         } 
16             return self::$loaded[$object];
17         } 
18     } 
19 ?>

这个文件就是失去加载对象,因为后咱们或许会见加上是MVC系统,会出model,helper,config等等的零部件。如果加载的机件不在有效
的限外,我们抛开来一个分外。如果在的话,我们实例化一个目标,其实这里用了么设计模式。也就是是这目标实际就算只好是一个实例化对象,如果没有实例化,
创建一个,如果是的,则非实例化。

吓,因为我们现若是加载的凡router组件,所以我们看下router.php文件,这个文件的意就是是映射URL,对URL进行辨析。
router.php

 1 <?php 
 2 class router 
 3 {
 4  private $route;
 5  private $controller;
 6  private $action;
 7  private $params;
 8  public function __construct()
 9  { 
10     $path = array_keys($_GET); 
11     if (!isset($path[0]))
12     { 
13         if (!empty($default_controller)) 
14         $path[0] = $default_controller; 
15         else 
16         $path[0] = "index"; 
17     }
18      $route= $path[0];
19      $this->route = $route;
20      $routeParts = split( "/",$route);
21      $this->controller=$routeParts[0];
22      $this->action=isset($routeParts[1])? $routeParts[1]:"base";
23      array_shift($routeParts);
24      array_shift($routeParts);
25      $this->params=$routeParts;
26      } 
27     public function getAction() 
28     { 
29     if (empty($this->action)) 
30     $this->action="main";
31     return $this->action;
32     } 
33     public function getController() 
34     { 
35     return $this->controller; 
36     } 
37     public function getParams() 
38     { 
39     return $this->params;
40     }
41  } 
42 ?>

俺们好看看,首先我们是将到$_GET,用户Request的URL,然后由URL里我们分析出Controller和Action,以及Params
比如我们的地方是http://www.tinoweb.cn/user/profile/id/3
那由地方的地址,我们得以拿到controller是user,action似乎profile,参数是id以及3

OK我们看最后一句子,就是

1 dispatcher::dispatch($router);

 

随即词话的意很明亮,就是以到URL解析的结果,然后通过dispatcher来散发controlloer及action来Response给用户
好,我们来拘禁下dispatcher.php文件

 1 <? 
 2 class dispatcher 
 3 {
 4  public static function dispatch($router) 
 5 { 
 6  global $app; ob_start();
 7  $start = microtime(true);
 8  $controller = $router->getController();
 9  $action = $router->getAction();
10  $params = $router->getParams();
11  $controllerfile = "app/controllers/{$controller}.php";
12  if (file_exists($controllerfile)){ require_once($controllerfile);
13  $app = new $controller();
14  $app->setParams($params);
15  $app->$action();
16  if (isset($start))
17  echo " Tota1l time for dispatching is : ".(microtime(true)-$start)." seconds. ";
18  $output = ob_get_clean();
19  echo $output;
20  }
21 
22 else
23 { 
24 throw new Exception("Controller not found"); 
25 } 
26 }
27 } 
28 ?>

这仿佛非常扎眼,就是拿到$router来,寻找文件中之controller和action来应对用户之伸手。

OK,我们一个概括的,MVC结构,就这么,当然这里还免可知算是一个不行完整的MVC,因为这里尚尚未涉嫌到View和Model,有空我重新此丰富。

俺们来写个Controller文件来测试下端的此系统。

咱以app/controllers/下开创一个user.php文件

 1  //user.php 
 2 <?php 
 3 class user {
 4  function base() { }
 5  public function login() 
 6 {
 7  echo 'login html page';
 8  } 
 9 public function register()
10  { 
11 echo 'register html page'; 
12 } 
13 public function setParams($params)
14 {
15  var_dump($params); 
16 } 
17 } 
18 ?>

接下来您可于浏览器中输入http://localhost/index.php?user/register 或者
http://localhost/index.php?user/login来测试下。

 

相关文章