今回は、PHPでルーティングとクラスの自動読み込みを実装する手順について詳しく説明します。 PHPでルーティングとクラスの自動読み込みを実装する手順で詳しく説明されている注意事項とは何ですか。以下は実際的なケースですので、見てみましょう。
プロジェクトディレクトリは以下の通りですエントリーファイルindex.php
<?php define('WEBROOT', 'C:/Users/Administrator/Documents/NetBeansProjects/test'); require_once(WEBROOT.'/core/environment.php'); coreapp::run(); //クラス自動読み込みファイルenvironment.php
<?php //根据类名来include文件 class loader { //找到对应文件就include static function load($name) { $file = self::filepath($name); if ($file) { return include $file; } } static function filepath($name, $ext = '.php') { if (!$ext) { $ext = '.php'; } $file = str_replace('', '/', $name) . $ext; //类名转路径 $path .= WEBROOT . '/' . $file; if (file_exists($path)) { return $path; //找到就返回 } return null; } } spl_autoload_register('loader::load');ここでのクラスの読み込みルールは
coreapp::run() </ルートに対応する code> ディレクトリ /core/app.php の <code>run()
メソッドは、spl_autoload_register()
関数を使用して、特定のクラス名の自動ロードを実装します。が呼び出されると、自動的に実行されます。 < code>spl_autoload_register('loader::load') は、クラス名に従って、対応するクラス ファイルをインクルードします。 coreapp::run()
对应 根目录/core/app.php 的 run()
方法,用到了spl_autoload_register()
函数实现自动加载,当调用某个类名的时候,会自动执行spl_autoload_register('loader::load')
,根据类名include对应的类文件。
app.php入口文件执行的方法开始跑框架流程
<?php class coreapp { static function run() { $a = $_SERVER['REQUEST_URI']; $uri = rtrim(preg_replace('/\?.*/', '', $_SERVER['REQUEST_URI']), '/'); $params = explode('/', trim($uri, '/')); $count = count($params); if ($count > 1) { $controller = $params[0]; $method = $params[1]; } elseif ($count == 1) { $controller = 'index'; $method = $params[0]; } else { } $filename = WEBROOT . '/controller/' . $controller . '.php'; $controller = 'controller'.$controller; try { if (!file_exists($filename)) { throw new Exception('controller ' . $controller . ' is not exists!'); return; } include($filename); if (!class_exists($controller)) { throw new Exception('class ' . $controller . ' is not exists'); return; } $obj = new ReflectionClass($controller); if (!$obj->hasMethod($method)) { throw new Exception('method ' . $method . ' is not exists'); return; } } catch (Exception $e) { echo $e; //展示错误结果 return; } $newObj = new $controller(); call_user_func_array(array($newObj, $method), $params); } }
根据请求uri去找对应的controller, 用call_user_func_array()
的方式调用controller里的方法
根目录/controller/test.php
<?php class controllertest { public function write($controller, $method) { //configtest::load('test'); modeltest::write($controller, $method); } }
这里其实调用不一定要调用model里的test方法,可以调model目录下的任意文件,在此之前可以去都读一些config文件等等操作。
根目录/model/test.php
<?php class modeltest { public function write($model, $method) { echo 'From controller:'.$model.' to model: ' . $model . ' ,method: ' . $method; } }
例如hostname/test/write 这个请求就会从入口文件进来,经过coreapp::run
就会找到controller下对应的的controllertest类,执行write()
app.phpエントリファイルを実行するメソッドは、フレームワークプロセスの実行を開始します
リクエストURIに従って対応するコントローラーを見つけ、call_user_func_array()
を使用してコントローラー内のメソッドを呼び出します
ルート ディレクトリ/コントローラー /test.php
rrreee 実際、ここでの呼び出しは必ずしもモデル内のテスト メソッドを呼び出す必要はありません。その前に、いくつかの設定ファイルを読み取ることができます。およびその他の操作。 ルートディレクトリ/model/test.php
rrreee
coreapp::run
の後に、対応するcontrollertestを見つけます。コントローラーの下のクラスで、write()
メソッドを実行しますこの記事の事例を読んだ後は、このメソッドを習得したと思います。さらに興味深い情報については、 に関する他の関連記事に注目してください。 PHPの中国語サイトです!
推奨書籍:
以上がPHPでルーティングとクラスの自動ロードを実装する手順の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。