今回は 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()
rrreee
リクエストURIに従って対応するコントローラーを見つけ、call_user_func_array()
を使用してコントローラー内のメソッドを呼び出しますルート ディレクトリ/コントローラー /test.php
rrreee 実際、ここでの呼び出しは必ずしもモデル内のテスト メソッドを呼び出す必要はありません。その前に、いくつかの設定ファイルを読み取ることができます。およびその他の操作。
ルートディレクトリ/model/test.php
たとえば、リクエストhostname/test/writeは、coreapp::run
の後に、対応するcontrollertestを見つけます。コントローラーの下のクラスで、write()
メソッドを実行しますこの記事の事例を読んだ後は、このメソッドを習得したと思います。さらに興味深い情報については、 に関する他の関連記事に注目してください。 PHPの中国語サイトです!
以上がPHP はルーティングとクラスの自動ロードを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。