php框架開發二(SPL庫和controller)

根據上話的目錄結構(如果不清楚的可以看上一篇)。我在simple文件夾內新建瞭一個simple.php.

[php]
<p>require 'includes/exceptions.php'; 
require 'includes/autoloader.php'; 
session_start();</p><p>//$view = new view(); 
lib::set_item('controller' , new controller()); 
lib::get_item('controller' , lib::PERSIST_STORGE)->render(); 
//$content = $view->finish();</p> 
這一章主要是講SPL,所以我們隻看第二行的autoloader.php.當我們在index.php中加入

[php] 
require 'simple/simple.php'; 
之後。

我們看一下autoloader.php的源碼

[php]
<?php 
class autoloader{ 
     
    public static function includesautoloader($class){ 
        $path = defined('SIMPLE_PATH') ? SIMPLE_PATH : $_SERVER['DOCUMENT_ROOT']; 
        $file_name = $path . '/includes/' . $class . '.php'; 
        if(is_readable($file_name)) 
            require $file_name; 
    } 
     
    public static function modulesautoloader($class){ 
        $path = defined('SIMPLE_PATH') ? SIMPLE_PATH : $_SERVER['DOCUMENT_ROOT']; 
        $file_name = $path . '/modules/' . $class . '.php'; 
        if(is_readable($file_name)) 
            require $file_name; 
    } 
     
    public static function controllerautoloader($class){ 
        $path = defined('SIMPLE_PATH') ? SIMPLE_PATH : $_SERVER['DOCUMENT_ROOT']; 
        $file_name = $path . '/controller/' . $class . '.php'; 
        if(is_readable($file_name)) 
            require $file_name; 
    } 
 

 
spl_autoload_register('autoloader::includesautoloader'); 
spl_autoload_register('autoloader::modulesautoloader'); 
spl_autoload_register('autoloader::controllerautoloader'); 

這個類都是靜態方法,當引用這個PHP文件後,程式會自動載入這三個文件夾下的內容,這樣我們不用重復去required 或include。如果對SPL有不瞭解的,可以直接去百度,這裡隻是告訴大傢,這個SPL作用相當廣。

然後在includes文件夾內新建一個lib.php

[html]
<?php 
class lib{ 
     
    const SETTING_ARRAY = true; 
    const PERSIST_STORGE = false; 
     
    public static function set_item($name , $value , $is_array = false){ 
        if($is_array){ 
            $_SESSION[$name]   = array(); 
            $_SESSION[$name][] = $value; 
        } 
        else{ 
            $_SESSION[$name] = $value; 
        } 
    } 
     
    public static function get_item($name , $persist = true){ 
        $result = null; 
        if(isset($_SESSION[$name])){ 
            $result = $_SESSION[$name]; 
        } 
        if(!$persist){ 
            unset($_SESSION[$name]); 
        } 
        return $result; 
    } 
     
    public static function sendto($url = ''){ 
        if(empty($url)){ 
            $url  = '/'; 
        } 
        die(header('Location:' . $url)); 
    } 

這個類目前隻用於設置SESSION相關的內容。

當執行到lib::set_item('controller' , new controller());時,這裡新建瞭一個控制器對象,並對象存入SESSION中。

controller.php

[php] 
<?php 
class controller{ 
    //URL部分 
    protected $parts; 
    //方法參數 
    protected $params; 
     
    public function __construct(){ 
        $this->parts = array(); 
        $this->analysis(); 
    } 
     
    public function analysis(){ 
        $path_info = $_SERVER['PATH_INFO']; 
        if(substr($path_info , 0 , 1) == '/'){ 
            $path_info = substr($path_info , 1); 
        } 
        $parts = explode('/' , $path_info); 
        if(emptyempty($parts[0]))  $parts[0] = 'index'; 
        if(emptyempty($parts[1]))  $parts[1] = 'demo'; 
         
        $this->parts = $parts; 
        array_shift($parts); 
        array_shift($parts); 
        $this->params = $parts; 
    } 
     
    public function render(){ 
        if(!class_exists($this->parts[0])){ 
            throw new ControllerDoesntExistsException($this->parts[0] . ' not exists!'); 
        } 
        if(!method_exists($this->parts[0] , $this->parts[1])){ 
            throw new ActionDoesntExistsException($this->parts[0] . 'of ' . $this->parts[1] . ' not exists!'); 
        } 
         
        $new_controller = new $this->parts[0]; 
        $called = call_user_func_array(array($new_controller , $this->parts[1]) , $this->params); 
        if($called === false){ 
            throw new ActionFailedException($this->parts[0] . 'of ' . $this->parts[1] . ' failed to excute property!'); 
        } 
    } 

這個類隻用PATH_INFO模式來獲取調用的控制器和ACTION,並將參數傳遞到相應的ACTION方法裡。當controller初始化之後,會自動分析PATH_INFO的內容,

lib::get_item('controller' , lib::PERSIST_STORGE)->render();

然後調用render()就會在相應的控制器目錄找到控制器和ACTION。

例如我在controller文件夾內新建一個index.php

[php] 
<?php 
class index{ 
     
    public function demo(){ 
        echo "sdfsdf"; 
    } 

那麼執行https://localhost/index.php/index/demo就會輸出"sdfsdf";(這是我的本地路徑)。

 

以上代碼難度不高,如果沒有看懂的同學,請Q我,也可以去PHP官網上去查找相應函數的用法。

下一節相會對視圖作一個簡單的介紹。
 作者:tomyjohn

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *