ホームページ >バックエンド開発 >PHPチュートリアル >PHPフレームワーク開発2(SPLライブラリとコントローラ)

PHPフレームワーク開発2(SPLライブラリとコントローラ)

WBOY
WBOYオリジナル
2016-06-13 13:14:54839ブラウズ

PHP フレームワーク開発 2 (SPL ライブラリとコントローラー)

上記のディレクトリ構成に従います (よくわからない場合は、前の記事を読んでください)。 simpleフォルダーに新しいsimple.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 について説明するため、index.php に

を追加するときの autoloader.php の 2 行目のみを確認します。
require 'simple/simple.php';

その後。

autoloader.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 ファイルが参照されると、プログラムはこれら 3 つのフォルダーの内容を自動的にロードするため、繰り返し要求したりインクルードしたりする必要はありません。 SPL について何も知らない場合は、直接 Baidu にアクセスしてください。この SPL には幅広い機能があることだけをお伝えしておきます。

次に、includes フォルダーに新しい lib.php を作成します

<?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', newcontroller()); が実行されると、ここで新しいコントローラー オブジェクトが作成され、そのオブジェクトが SESSION に保存されます。

controller.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(empty($parts[0]))  $parts[0] = 'index';
		if(empty($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 メソッドに渡します。コントローラーが初期化されると、PATH_INFO の内容が自動的に分析されます。

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

次に render() を呼び出すと、対応するコントローラー ディレクトリでコントローラーと ACTION が見つかります。

たとえば、コントローラーフォルダーに新しいindex.phpを作成します

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

次に http://localhost/index.php/index/demo を実行すると、「sdfsdf」が出力されます (これは私のローカル パスです)。

上記のコードは難しいものではありません。わからない場合は、PHP 公式 Web サイトにアクセスして、対応する関数の使用方法を見つけることもできます。

次のセクションでは、ビューについて簡単に説明します。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。