復制代碼 代碼如下:
Route::get('/', function()
{
return 'Hello World " /> 最近中文字幕视频国语中文字幕,99re免费视频,亚洲精品1区

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Laravel框架路由配置總結、設置技巧大全

基本路由

您的應用程序的絕大多數路由將在 app/routes.php 文件中定義。Laravel 中最簡單的路由由一個 URI 和一個閉包調用組成。

基本 GET 路由
復制代碼 代碼如下:
Route::get('/', function()
{
return 'Hello World';
});

基本 POST 路由
復制代碼 代碼如下:
Route::post('foo/bar', function()
{
return 'Hello World';
});

注冊一個路由以響應所有 HTTP 方法
復制代碼 代碼如下:
Route::any('foo', function()
{
   return 'Hello World';
});

強制一個路由必須通過 HTTPS 訪問
復制代碼 代碼如下:
Route::get('foo', array('https', function()
{
    return 'Must be over HTTPS';
}));

經常您需要根據路由產生 URLs,您可以通過使用 URL::to 方法:
復制代碼 代碼如下:$url = URL::to('foo');

路由參數
復制代碼 代碼如下:
Route::get('user/{id}', function($id)
{
return 'User '.$id;
});

可選的路由參數
復制代碼 代碼如下:
Route::get('user/{name?}', function($name = null)
{
return $name;
});

帶默認值的可選的路由參數
復制代碼 代碼如下:
Route::get('user/{name?}', function($name = 'John')
{
return $name;
});

帶正則表達式約束的路由
復制代碼 代碼如下:
Route::get('user/{name}', function($name)
{
//
})
->where('name', '[A-Za-z]+');
Route::get('user/{id}', function($id)
{
//
})
->where('id', '[0-9]+');

路由過濾器

  路由過濾器提供了一種限制訪問指定路由的簡單的方法,這在您需要為您的站點創建需要認證區域的時候非常有用。Laravel 框架中包含了一些路由過濾器,比如 auth 過濾器、auth.basic 過濾器、guest 過濾器、以及 csrf 過濾器。它們被存放在 app/filters.php 文件中。

定義一個路由過濾器
復制代碼 代碼如下:
Route::filter('old', function()
{
if (Input::get('age') < 200)
{
return Redirect::to('home');
}
});

  如果一個響應從一個路由過濾器中返回,這個響應即被認為是這個請求的響應,路由將不被執行,任何關于這個路由的 after 過濾器也將被取消執行。

  為一個路由指定一個路由過濾器
復制代碼 代碼如下:
Route::get('user', array('before' => 'old', function()
{
return 'You are over 200 years old!';
}));

為一個路由指定多個路由過濾器

復制代碼 代碼如下:
Route::get('user', array('before' => 'auth|old', function()
{
return 'You are authenticated and over 200 years old!';
}));

指定路由過濾器參數
復制代碼 代碼如下:
Route::filter('age', function($route, $request, $value)
{
//
});
Route::get('user', array('before' => 'age:200', function()
{
return 'Hello World';
}));

  當路由過濾器接收到作為第三個參數的響應 $response:
復制代碼 代碼如下:
Route::filter('log', function($route, $request, $response, $value)
{
//
});

基本路由過濾器的模式

您可能希望根據 URI 為一組路由指定過濾器。
復制代碼 代碼如下:
Route::filter('admin', function()
{
//
});
Route::when('admin/*', 'admin');

在上面的例子中,admin 過濾器將應用帶所有以 admin/ 開頭的路由。星號作為一個通配符,將適配到所有字符的組合。

您也可以通過指定 HTTP 方法約束模式過濾器:

復制代碼 代碼如下:
Route::when('admin/*', 'admin', array('post'));

過濾器類

對于高級的過濾器,您可以使用一個類代替閉包函數。因為過濾器類是位于應用程序之外的 IoC 容器,您能夠在過濾器中使用依賴注入,更易于測試。

定義一個過濾器類
復制代碼 代碼如下:
class FooFilter {
public function filter()
{
// Filter logic...
}
}

注冊一個基于類的過濾器
復制代碼 代碼如下:
Route::filter('foo', 'FooFilter');

命名路由

命名路由在更易于在生成跳轉或 URLs 時指定路由。您可以像這樣為路由指定一個名字:
復制代碼 代碼如下:
Route::get('user/profile', array('as' => 'profile', function()
{
//
}));

您也可以為控制器的方法指定路由名字:
復制代碼 代碼如下:
  Route::get('user/profile', array('as' => 'profile', 'uses' =>
'UserController@showProfile'));

  現在您在生成 URLs 或跳轉的時候使用路由的名字:

復制代碼 代碼如下:
$url = URL::route('profile');
$redirect = Redirect::route('profile');

您可以使用 currentRouteName 方法獲取一個路由的名字:

復制代碼 代碼如下:
$name = Route::currentRouteName();

路由組

有些時候您可能希望應用過濾器到一組路由。您不必要為每個路由指定過濾器,可以使用路由組:
復制代碼 代碼如下:
Route::group(array('before' => 'auth'), function()
{
Route::get('/', function()
{
// Has Auth Filter
});
Route::get('user/profile', function()
{
// Has Auth Filter
});
});

子域名路由

  Laravel 路由也能夠處理通配符的子域名,并且從域名中獲取通配符參數:

注冊子域名路由
復制代碼 代碼如下:
Route::group(array('domain' => '{account}.myapp.com'), function()
{
Route::get('user/{id}', function($account, $id)
{
//
});
});

路由前綴

一組路由可以通過在屬性數組中使用 prefix 選項為路由組添加前綴:

為路由組添加前綴
復制代碼 代碼如下:
Route::group(array('prefix' => 'admin'), function()
{
Route::get('user', function()
{
//
});
});

路由模型綁定

  模型綁定提供了一個簡單的方法向路由中注入模型。比如,不僅注入一個用戶的 ID,您可以根據指定的 ID 注入整個用戶模型實例。首先使用 Route::model 方法指定所需要的模型:

為模型綁定一個變量
復制代碼 代碼如下:
Route::model('user', 'User');

然后, 定義一個包含 {user} 參數的路由:
復制代碼 代碼如下:
Route::get('profile/{user}', function(User $user)
{
//
});

  因為我們已經綁定 {user} 參數到 User 模型,一個 User 實例將被注入到路由中。因此,比如一個 profile/1 的請求將注入一個 ID 為 1 的 User 實例。

  注意: 如果在數據庫中沒有找到這個模型實例,將引發404錯誤。

  如果您希望指定您自己定義的沒有找到的行為,您可以為 model 方法傳遞一個閉包作為第三個參數:
復制代碼 代碼如下:
Route::model('user', 'User', function()
{
throw new NotFoundException;
});

  有時您希望使用自己的方法處理路由參數,可以使用 Route::bind 方法:
復制代碼 代碼如下:
Route::bind('user', function($value, $route)
{
return User::where('name', $value)->first();
});

引發404錯誤

  有兩種方法在路由中手動觸發一個404錯誤。首先,您可以使用 App::abort 方法:

復制代碼 代碼如下:
App::abort(404);

其次,您可以拋出一個 Symfony/Component/HttpKernel/Exception/NotFoundHttpException 的實例。

更多關于處理404異常和為這些錯誤使用使用自定義響應的信息可以在 錯誤 章節中找到。

路由至控制器

Laravel 不僅允許您路由至閉包,也可以路由至控制器類,甚至允許創建 資源控制器.

更多信息請訪問 控制器 文檔。

php技術Laravel框架路由配置總結、設置技巧大全,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 特大巨黑吊在线播放 | 成年人免费在线视频网站 | 午夜视频免费 | 一本久久精品一区二区 | 亚洲性色成人 | 国产综合色在线视频区色吧图片 | 亚洲国产精品一区二区三区 | 91在线精品视频 | 国产成人亚洲综合小说区 | 色黄视频 | 色呦呦免费视频 | 国产熟睡乱子伦视频观看看 | 日本高清视频在线www色 | 久久99国产精品久久99软件 | 久久久青草青青亚洲国产免观 | 国产视频一区二区在线观看 | 国产91精品高跟丝袜在线 | 免费视频91| 国产成人aa视频在线观看 | 黄色在线免费看 | 亚洲国产精品久久久久婷婷软件 | 91在线视频免费91 | 九月婷婷综合婷婷 | 免费popnhub国产在线视频 | 国产成人精视频在线观看免费 | 免费观看91视频 | 铃原爱蜜莉福利一区在线观看 | 麻豆国产精品免费视频 | 狠狠综合久久综合88亚洲日本 | 天天天干 | 天天操天天透 | 久久精品国产精品亚洲20 | 不良网站在线观看 | 久久精品乱子伦观看 | 国产无套在线播放 | 99国内视频 | 一区二区三区不卡免费视频97 | 干色网| 欧美一级特黄aa大片婷婷 | 99在线小视频 | 久久久久久久久久综合情日本 |