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

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

Jun 13, 2016 pm 01:14 PM
controller name path php

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 までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

CakePHP のロギング CakePHP のロギング Sep 10, 2024 pm 05:26 PM

CakePHP へのログインは非常に簡単な作業です。使用する関数は 1 つだけです。 cronjob などのバックグラウンド プロセスのエラー、例外、ユーザー アクティビティ、ユーザーが実行したアクションをログに記録できます。 CakePHP でのデータのログ記録は簡単です。 log()関数が提供されています

See all articles