FuelPHP-ルーティング

ルーティングマップは、特定のコントローラーのメソッドへのURIを要求します。この章では、の概念について説明します。routing 詳細はFuelPHPで。

構成

ルート構成ファイルは次の場所にあります。 fuel/app/config/routes.php。デフォルトroutes.php ファイルは次のように定義されます-

<?php 
   return array ( 
      '_root_'  => 'welcome/index',   // The default route 
      '_404_'   => 'welcome/404',     // The main 404 route 
      'hello(/:name)?' => array('welcome/hello', 'name' => 'hello'), 
   );

ここに、 _root_は事前定義されたデフォルトルートであり、アプリケーションがルートパスで要求されたときに一致します。例:http:// localhost:8080 /_root_の値は、コントローラーと、一致したときに解決されるアクションです。welcome/indexController_Welcomeコントローラーとaction_indexアクションメソッドに解決されます。同様に、次の予約済みルートがあります。

  • root −URIが指定されていない場合のデフォルトルート。

  • 403 −HttpNoAccessExceptionが見つかるとスローされます。

  • 404 −ページが見つからない場合に戻ります。

  • 500 −HttpServerErrorExceptionが見つかるとスローされます。

シンプルなルーティング

ルートはリクエストURIと比較されます。一致するものが見つかった場合、リクエストはURIにルーティングされます。単純なルーティングは次のように説明されます。

return array ( 
   'about'  => 'site/about', 
   'login' => 'employee/login', 
);

ここに、 about http:// localhost:8080 / aboutに一致し、コントローラーのController_Siteとアクションメソッドのaction_aboutを解決します

login http:// localhost:8080 / loginに一致し、コントローラーのController_Loginとアクションメソッドのaction_loginを解決します

高度なルーティング

ルートに任意の正規表現を含めることができます。Fuelは、次の高度なルーティング機能をサポートしています-

  • :any −これは、URIのその時点以降のすべてに一致し、「何もない」には一致しません。

  • :everything −:anyと同様ですが、「nothing」にも一致します

  • :segment −これはURIの1つのセグメントにのみ一致しますが、そのセグメントは何でもかまいません

  • :num −これは任意の数に一致します

  • :alpha −これは、UTF-8を含むすべての英字に一致します

  • :alnum −これは、UTF-8を含むすべての英数字に一致します

たとえば、次のルートはURI http:// localhost:8080 / hello / FuelPHPに一致し、コントローラーController_Welcome、およびアクションaction_helloを解決します

'hello(/:name)?' => array('welcome/hello', 'name' => 'hello'),

Controller_Welcomeの対応するアクションメソッドは次のとおりです。

public function action_hello() { 
   $this->name = Request::active()->param('name', 'World'); 
   $message = "Hello, " . $this->name;  
   echo $message; 
}

ここでは、Requestクラスを使用してURLからnameパラメーターを取得しました。名前が見つからない場合は、デフォルト値としてWorldを使用しています。リクエストレスポンスの章でリクエストクラスを学習します。

結果

HTTPメソッドアクション

FuelPHPは、HTTPメソッドのプレフィックス付きアクションに一致するルートをサポートしています。以下は基本的な構文です。

class Controller_Employee extends Controller { 
   public function get_index() { 
      // called when the HTTP method is GET. 
   }  
   public function post_index(){ 
      // called when the HTTP method is POST. 
   } 
}

次のように、構成ファイルのHTTP動詞に基づいてURLをコントローラーとアクションにルーティングできます。

return array ( 
   // Routes GET /employee to /employee/all and POST /employee to /employee/create 
   ‘employee’ => array(array('GET', new Route(‘employee/all')), array('POST', 
      new Route(‘employee/create'))), 
);