路由
簡介:
- 將用戶的請求轉發給相應的程序進行處理
- 作用:建立url和程序之間的映射
- 請求類型:get、post、put、patch、delete
- 目錄:app/http/routes.php
基本路由:接收單種請求類型
//get請求 Route::get('hello1',function(){return 'hello world'; })
//post請求 Route::post('hello2',function(){return 'hello world'; })
多請求路由:接收多種請求類型
//get、post請求//match用來匹配指定請求的類型Route::match(['get','post'],'mulity',function(){return 'mulity request';})//any匹配所有類型的請求Route::any('mulity2',function(){return 'mulity2 request';})
路由參數
Route::get('user/{id}', function ($id) {return 'User '.$id;});Route::get(‘user/{name?}’,function($name = null){Return ‘name’.$name});Route::get('user/{name}', function ($name) {//})->where('name', '[A-Za-z]+');Route::get('user/{id}', function ($id) {//})->where('id', '[0-9]+');Route::get('user/{id}/{name}', function ($id, $name) {//})->where(['id' => '[0-9]+', 'name' => '[a-z]+']);
路由別名
Route::get('user/profile', ['as' => 'profile', function () {//}]);
路由群組
//路由前綴 Route::group(['prefix' => 'admin'], function () {Route::get('users', function () {// Matches The "/admin/users" URL });});
路由輸出視圖
Route::get('/', function () {return view('welcome');});
控制器
簡介
- 將請求邏輯交由控制類處理,而不是都交給一個routes.php文件
- 控制器可以將相應的php請求邏輯集合到一個類中
- 存放位置app/Http/Controllers
基礎控制器:在laravel中,默認所有的控制器都繼承了控制器基類
<?php//使用命名空間namespace App\Http\Controllers;use App\User;use App\Http\Controllers\Controller;class UserController extends Controller{/*** 顯示指定用戶的個人信息* * @param int $id* @return Response*/public function showProfile($id){return view('user.profile', ['user' => User::findOrFail($id)]);}}
route 訪問控制器,利用 PHP 的命名空間機制以嵌套的方式組織控制器在
App\Http\Controllers
目錄下的結構的話,引用類時只需指定相對于App\Http\Controllers
根命名空間的類名即可//@后面內容為所要訪問的方法Route::get('foo', 'Photos\AdminController@method');//也可以指定控制器路由的名稱Route::get('foo', ['uses' => 'FooController@method', 'as' => 'name']);//通過助手方法來生成ur$url = route('name');//傳參$idRoute::get('user/{id}',['uses'=> 'MemberController@info'])->where('id', '[0-9]+');