URLルーティング
MVCの肝の部分としてURLルーティングが挙げられます。今までASP.NETでは「.aspx」ファイルやフォルダがある場所のURLしか表示できませんでした。しかし、URLルーティングを利用することで、仮想的にURLマッピングを行えるようになります。
図4のソリューション構成の場合、通常ならばhttp://xxx/Views/Home/Index.aspxとなります。しかし、 URLルーティングを利用するとhttp://xxx/Home/IndexというURLになります(図5)。
URLルーティングの特徴
図5のURLルーティングは以下のコードにより実装されています。
public class HomeController : Controller { // ActionResultメソッドで返るActionResultオブジェクトは // そのままViewページにルーティングされる public ActionResult Index() { // Titleキーを利用するとブラウザのタイトルとして表示される // この場合はHome Pageが表示 ViewData["Title"] = "Home Page"; // ViewDataにキーと値を格納 ViewData["Message"] = "Welcome to ASP.NET MVC!"; // コントローラークラスのViewメソッドで、 // ルーティング先のViewPage名を設定する // パラメタが指定されない場合は // メソッド名と同名のViewPageに値を返す return View(); } }
上記メソッドが呼び出されるとコメントに書いてあるURLマッピングが行われます。例えば、「XXX」という名前のフォルダや、「.aspx」ファイルがなくとも、URLマッピングが行えるのです。そして、マッピングには表示するのに必要なメソッド名、パラメタなどを使用するので、シンプルに分かりやすいURLを構築できます(URLルーティング)。
このURLルーティングにより開発者は本来必要だったフォルダやファイルの構築から解放され、自分が構築したかったURLを簡潔に素早く実装できるようになりました。
なぜこのようなことができるようになったのでしょうか? ポイントはURLルーティングルールにあります。
URLルーティングルール
ASP.NET MVCプロジェクトを作成した時点で、ルーティングルールを「Global.asax」に自動生成します。原理として、Webアプリケーション起動時に一度だけ呼び出されるGlobal.asaxのApplication_Start
メソッドからRegisterRoutes
メソッドを呼び出してルーティングルールをルートコレクションに追加しています。
ルーティングルールは、「リクエストにより利用するURLの雛形を定義する」ことと、「リクエスト時にパラメタが足りない場合の雛形の初期値の設定」を行います。
以下のコードは既定で作成されるルーティングルールです。
public class GlobalApplication : System.Web.HttpApplication { public static void RegisterRoutes(RouteCollection routes) { // IgnoreRouteメソッドは // ルート特定のURLパターンの処理を停止させる // ここでは.axdの処理を停止するよう指定 routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); // MapRouteメソッドは新しいルーティングルールを // ルートコレクションに追加する // ここでは既定のルートとして // "http://xxx/Home/Index"へとルーティングされる routes.MapRoute( // Route name(ルート名) "Default", // URL with parameters(URLとパラメータ名) "{controller}/{action}/{id}", // Parameter defaults(既定のパラメータ値) new { controller = "Pubs", action = "Hello", id = "" } ); } // Webアプリケーション起動時に一度だけ呼び出されるメソッド protected void Application_Start() { RegisterRoutes(RouteTable.Routes); } }
"{controller}/{action}/{id}"はhttp://ApplicationURL/の後ろに表示されるURLです。ASP.NET MVCではこのMapRouteで追加されたコレクションのURLしか表示されません。
定義 | 概要 |
{controller} | Controller名(例えばPubsControllerならPubs)。 |
{action} | Viewメソッドを呼び出すController内のメソッド名。 |
{id} | Viewメソッドにパラメタが必要な場合に利用するパラメタ。 |
ルーティングルールは複数設定することができますが、リクエストによっては複数のルーティングルールに当てはまる場合があります。この時には、ルート名を指定することで、どのルートにパラメタを渡すか指定することができます。