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電腦。
Laravel中的常見路由有哪幾種
#一句話總結:
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);
1、Lararel的CSRF 保護保護表單安全措施是怎麼回事?
作用:Laravel 提供簡單的方法來保護你的應用程式不受到 跨站請求偽造 (CSRF) 攻擊。跨站請求偽造是一種惡意的攻擊,它利用已通過身份驗證的用戶身份來運行未經授權的命令。
實作:表單中加入如下這句好:{{csrf_field()}}。詳見程式碼
實質:就是在form表單中加入了一個token值; input type="hidden" name="_token" value="SqlDhf...一串隨機字符字串"
原則是:檢驗表單的token值是否合法,合法就通過,否則就不通過
<form method="POST" action="/profile"> {{ csrf_field() }} ... </form>
2、路由中的post請求方式如何書寫?
就是post方法:Route::post('check',"LoginController@check");
3、路由中的put請求如何實現?
路由寫法: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>4、Laravel頁面中如何一個頁面實現多種請求方式(我又可以get方式給頁面數據,用戶又可以搜尋框來post請求)?
match(指定請求):Route::match(['get','post'],'/',"IndexController@index ");
控制器程式碼:判斷使用者是否為post請求,如果是就輸出使用者搜尋的,否則輸出正常顯示到頁面的資料
any(全部請求)
:Route::any('/',"IndexController@index");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');實作:
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 |6、路由如何帶參數和多個參數? 大括號裡參數: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; }); :帶預設值保證不帶參數的時候有值
7、控制器中如何存取路由中所帶的參數? #########直接傳入參數,$_GET裡面沒有值###Route::get('UserInfo/{name}/{sex}',"IndexController@UserInfo"); // 新建UserInfo public function UserInfo($a,$sex1){ var_dump($a); var_dump($sex1); }
8、命名路由是什么以及作用?
是什么:就是给路由命名
实现:Route::get('abc',"IndexController@abc")->name('one');
作用:获取别名的url地址:控制器中:route('one');可以到以one为别名的控制器中
作用:通过命名路由实现重定向(实现重定向的一种方式):控制器中:return redirect()->route('one');
9、路由组命名空间的作用以及实现?
实现前后台控制器分离:需要在控制器目录下新建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中文網其他相關文章!

Laravel在後端開發中表現強大,通過EloquentORM簡化數據庫操作,控制器和服務類處理業務邏輯,並提供隊列、事件等功能。 1)EloquentORM通過模型映射數據庫表,簡化查詢。 2)業務邏輯在控制器和服務類中處理,提高模塊化和可維護性。 3)其他功能如隊列系統幫助處理複雜需求。

選擇Laravel開發項目是因為其靈活性和強大功能適應不同規模和復雜度的需求。 Laravel提供路由系統、EloquentORM、Artisan命令行等功能,支持從簡單博客到復雜企業級系統的開發。

Laravel和Python在開發環境和生態系統上的對比如下:1.Laravel的開發環境簡單,僅需PHP和Composer,提供了豐富的擴展包如LaravelForge,但擴展包維護可能不及時。 2.Python的開發環境也簡單,僅需Python和pip,生態系統龐大,涵蓋多個領域,但版本和依賴管理可能複雜。

Laravel是如何在後端邏輯中發揮作用的?它通過路由系統、EloquentORM、認證與授權、事件與監聽器以及性能優化來簡化和增強後端開發。 1.路由系統允許定義URL結構和請求處理邏輯。 2.EloquentORM簡化數據庫交互。 3.認證與授權系統便於用戶管理。 4.事件與監聽器實現松耦合代碼結構。 5.性能優化通過緩存和隊列提高應用效率。

Laravel受歡迎的原因包括其簡化開發過程、提供愉快的開發環境和豐富的功能。 1)它吸收了RubyonRails的設計理念,結合PHP的靈活性。 2)提供瞭如EloquentORM、Blade模板引擎等工具,提高開發效率。 3)其MVC架構和依賴注入機制使代碼更加模塊化和可測試。 4)提供了強大的調試工具和性能優化方法,如緩存系統和最佳實踐。

Django和Laravel都是全棧框架,Django適合Python開發者和復雜業務邏輯,Laravel適合PHP開發者和優雅語法。 1.Django基於Python,遵循“電池齊全”哲學,適合快速開發和高並發。 2.Laravel基於PHP,強調開發者體驗,適合小型到中型項目。

PHP和Laravel不是直接可比的,因為Laravel是基於PHP的框架。 1.PHP適合小型項目或快速原型開發,因其簡單直接。 2.Laravel適合大型項目或高效開發,因其提供豐富功能和工具,但學習曲線較陡,性能可能不如純PHP。

laravelisabackendframeworkbuiltonphp,設計ForweBapplicationDevelopment.itfocusessonserver-sideLogic,databasemagemention和Applicationstructure和CanBeintegratedWithFrontendTechnologiesLikeLikeVue.jsorreActeReacterVue.jsorreActforforfull-stackDevefloct。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。