laravel有6種路由:1、get,語法「Route::get($uri,$callback)」;2、post,語法「Route::post($uri,$callback)」; 3、put,語法「Route::put($uri, $callback)」;4、patch,文法「Route::patch($uri, $callback)」;5、delete,文法「Route::delete($ uri, $callback)」;6、options,文法「Route::options($uri, $callback)」。
本教學操作環境: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) 攻擊。跨站請求偽造是一種惡意的攻擊,它利用已通過身份驗證的用戶身份來運行未經授權的命令。
實作:表單中加入如下這句好:{{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請求,如果是就輸出使用者搜尋的,否則輸出正常顯示到頁面的資料
5、Laravel資源路由的使用實例及實作(實際項目用的比較多)?
實例:後台擁有許多模組,使用者模組、管理模組等(增、刪、改、查):這樣直接在路由中寫非常多非常麻煩
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');
| 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 |
$id; });多個參數:Route::get('UserInfo/#{name}/{sex}',function($name,$sex){
echo $name; echo $ sex; });可能帶或不可能帶的參數:問號預設值:Route::get('user/ edit/{id?}',function(
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视频教程
以上是laravel有幾種路由的詳細內容。更多資訊請關注PHP中文網其他相關文章!