這篇文章主要為大家展示了“Laravel中的常見路由有哪幾種”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Laravel中的常見路由有哪幾種”這篇文章吧。
laravel有6種路由:1、get,語法“Route::get(..)”;2、post,語法“Route::post(..)”;3、put,語法“Route::put(..)”;4、patch;5、delete;6、options。
本教程操作環境:windows7系統、Laravel6版,DELL G3電腦。
一句話總結:
6種:post,get,put,patch,delete,options
Route::get($uri, $callback); Route::post($uri, $callback); Route::put($uri, $callback); Route::patch($uri, $callback); Route::delete($uri, $callback); Route::options($uri, $callback);
作用:Laravel 提供簡單的方法保護你的應用不受到 跨站請求偽造 (CSRF) 攻擊??缯菊埱髠卧焓且环N惡意的攻擊,它利用已通過身份驗證的用戶身份來運行未經授權的命令。
實現:表單中添加如下這句好:{{csrf_field()}}。詳見代碼
實質:就是在form表單中添加了一個token值; input type="hidden" name="_token" value="SqlDhf...一串隨機字符串"
原理是:檢驗表單的token值是否合法,合法就通過,否則就不通過
<form method="POST" action="/profile"> {{ csrf_field() }} ... </form>
就是post方法:Route::post('check',"LoginController@check");
路由寫法:Route的put方法:Route::put('put','LoginController@put');
控制器寫法:就是基礎控制器的寫法
請求頁面設置請求類型為put:input type="hidden" name="_method" value="put"
路由中書寫
// put請求 Route::get('putWeb','LoginController@putWeb'); // put的處理頁面 Route::put('put','LoginController@put');
控制器書寫
// put請求頁面 public function putWeb(){ return view('putWeb'); } // put請求處理頁面 public function put(Request $request){ dd($request->input()); }
請求頁面書寫
<form action="put" method="post"> <p> {{csrf_field()}} <input type="hidden" name="_method" value="put"> User: <input type="text" name="user" id=""> </p> </form>
match(指定請求):Route::match(['get','post'],'/',"IndexController@index");
控制器代碼:判斷用戶是否為post請求,如果是就輸出用戶搜索的,否則輸出 正常顯示到頁面的數據
any(全部請求):Route::any('/',"IndexController@index");
實例:后臺擁有很多模塊,用戶模塊、管理模塊等(增、刪、改、查):這樣直接在路由中寫非常多非常麻煩
Route::get('user/index','UserController@index'); Route::get('user/add','UserController@add'); Route::get('user/edit','UserController@edit'); Route::post('user/insert','UserController@insert'); Route::post('user/update','UserController@update'); Route::get('user/del','UserController@del');
實現:resource方法:Route::resource('Admin','IndexController');
| GET|HEAD | Admin | Admin.index | App\Http\Controllers\IndexController@index | web | #展示頁面 | POST | Admin | Admin.store | App\Http\Controllers\IndexController@store | web | #添加操作 | GET|HEAD | Admin/create | Admin.create | App\Http\Controllers\IndexController@create | web | #添加頁面 | DELETE | Admin/{Admin} | Admin.destroy | App\Http\Controllers\IndexController@destroy | web | #刪除操作 | PUT|PATCH | Admin/{Admin} | Admin.update | App\Http\Controllers\IndexController@update | web | #更新操作 | GET|HEAD | Admin/{Admin} | Admin.show | App\Http\Controllers\IndexController@show | web | | GET|HEAD | Admin/{Admin}/edit | Admin.edit | App\Http\Controllers\IndexController@edit | web | #修改頁面 | GET|HEAD | api/user | | Closure | api,auth:api |
大括號里參數:Route::get('user/del/{id}',function($id){ echo $id; });
多個參數:Route::get('UserInfo/{name}/{sex}',function($name,$sex){ echo $name; echo $sex; });
可能帶或不可能帶的參數:問號+默認值:Route::get('user/edit/{id?}',function($id="默認值"){ echo $id; });:帶默認值保證不帶參數的時候有值
直接傳入參數,$_GET里面沒有值
Route::get('UserInfo/{name}/{sex}',"IndexController@UserInfo"); // 新建UserInfo public function UserInfo($a,$sex1){ var_dump($a); var_dump($sex1); }
是什么:就是給路由命名
實現:Route::get('abc',"IndexController@abc")->name('one');
作用:獲取別名的url地址:控制器中:route('one');可以到以one為別名的控制器中
作用:通過命名路由實現重定向(實現重定向的一種方式):控制器中:return redirect()->route('one');
實現前后臺控制器分離:需要在控制器目錄下新建Admin目錄和Home目錄 在目錄中新建控制器
在Route的group方法中指定命名空間:Route::group(['namespace'=>'Admin'],function(){
在Admin中的控制器要寫好命名空間,并且繼承控制器要use到控制器
//路由中代碼 Route::group(['namespace'=>'Admin'],function(){ Route::get('admin','IndexController@index'); Route::get('admin/user','UserController@index'); Route::get('admin/goods','GoodsController@index'); }); Route::group(['namespace'=>'Home'],function(){ Route::get('/','IndexController@index'); }); #需要在控制器目錄下新建Admin目錄和Home目錄 在目錄中新建控制器 #注意 需要修改命名空間 控制器中代碼 <?php namespace App\Http\Controllers\Admin; use Illuminate\Http\Request; use DB; use App\Http\Controllers\Controller; class UserController extends Controller { //index 方法 public function index(){ echo "我是后臺控制器User"; } }
以上是“Laravel中的常見路由有哪幾種”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。