主頁 > 知識庫 > Laravel5.1 框架Middleware中間件基本用法實例分析

Laravel5.1 框架Middleware中間件基本用法實例分析

熱門標簽:揚州地圖標注app 百應(yīng)電話機器人服務(wù) 河南電銷卡外呼系統(tǒng)哪家強 青島語音外呼系統(tǒng)招商 山西探意電話機器人 昭通辦理400電話 岳陽外呼型呼叫中心系統(tǒng)在哪里 山西回撥外呼系統(tǒng) 騰訊外呼管理系統(tǒng)

本文實例講述了Laravel5.1 框架Middleware中間件基本用法。分享給大家供大家參考,具體如下:

中間件?什么鬼? 大家第一次接觸這個詞都會有這么個疑問,但它其實沒那么神秘。

一句話就可以解釋它:過濾HTTP請求專用機制。

為什么要使用中間件?

過濾HTTP請求是可以寫在別的地方,比如說控制器中 路由中,BUT 抽象出來就有它的理由,比如說Laravel自帶的Auth中間件 它要求必須是登錄進來的用戶才有權(quán)訪問 如果沒有登錄就跳轉(zhuǎn)到登錄頁面,這樣的邏輯在很多場景都會用到 這很明顯了吧 你不可能在每個控制器或每一個路由都單獨實現(xiàn)以便,直接抽出來多方便。

1 使用中間件

1.1 創(chuàng)建中間件

咱創(chuàng)建中間件是使用artisan控制臺的:

php artisan make:middleware TestMiddleware

創(chuàng)建好后位于:app/Http/Middleware

1.2 解讀中間件

首先我們來看看新創(chuàng)建的中間件是什么模樣兒:

class TestMiddleware
{
  /**
   * Handle an incoming request.
   *
   * @param \Illuminate\Http\Request $request
   * @param \Closure $next
   * @return mixed
   */
  public function handle($request, Closure $next)
  {
    return $next($request);
  }
}

解讀:middleware中只有 “handle”函數(shù) 這個函數(shù)呢接受兩個參數(shù)

它的流程是接受request參數(shù) 取出一些東西做驗證 如果邏輯通過 執(zhí)行next閉包。

如果你還是不太懂的話 沒關(guān)系 咱上實例

1.3 編寫中間件

  public function handle($request, Closure $next)
  {
    // 如果傳入的id參數(shù)等于0 就跳轉(zhuǎn)到首頁。
    if ($request->input('id') == 0){
      return redirect('/');
    }
    // id參數(shù)不等于0 則為通過 進行默認的下一步操作。
    return $next($request);
  }

完事兒后我們需要在 app/Http/Kernel.php 中進行注冊:

  /**
   * The application's global HTTP middleware stack.
   *
   * @var array
   */
  protected $middleware = [
    \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
    \App\Http\Middleware\EncryptCookies::class,
    \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
    \Illuminate\Session\Middleware\StartSession::class,
    \Illuminate\View\Middleware\ShareErrorsFromSession::class,
    \App\Http\Middleware\VerifyCsrfToken::class,
  ];
  /**
   * The application's route middleware.
   *
   * @var array
   */
  protected $routeMiddleware = [
    'auth' => \App\Http\Middleware\Authenticate::class,
    'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
    // 把我們創(chuàng)建的middleware注冊到這里
    'test' => \App\Http\Middleware\TestMiddleware::class,
  ];

注意:我們可以瞧見啊 Kernel 中有兩個數(shù)組 如果你希望在全局中使用 就注冊在middleware數(shù)組中,如果你想要局部使用middleware 那么就在routeMiddleware數(shù)組中注冊。

1.4 使用中間件

好了,注冊完之后我們來用用吧:

Route::get('/test-middleware',['middleware'=>'test',function(){
  return 'HI';
}]);

當我們輸入:http://localhost:8000/test-middleware?id=1 時會在頁面上輸出HI 當輸入 http://localhost:8000/test-middleware?id=0 時會返回首頁。

更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家基于Laravel框架的PHP程序設(shè)計有所幫助。

您可能感興趣的文章:
  • Laravel中間件實現(xiàn)原理詳解
  • Laravel框架實現(xiàn)利用中間件進行操作日志記錄功能
  • Laravel的throttle中間件失效問題解決方法
  • Laravel獲取當前請求的控制器和方法以及中間件的例子
  • laravel框架中間件 except 和 only 的用法示例
  • Laravel框架基于中間件實現(xiàn)禁止未登錄用戶訪問頁面功能示例
  • 淺談Laravel中的三種中間件的作用
  • Laravel5.1框架注冊中間件的三種場景詳解
  • laravel利用中間件防止未登錄用戶直接訪問后臺的方法
  • laravel利用中間件做防非法登錄和權(quán)限控制示例
  • 基于Laravel 多個中間件的執(zhí)行順序詳解
  • laravel框架中間件簡單使用方法示例

標簽:鎮(zhèn)江 南陽 寶雞 湛江 婁底 黃南 銅川 宜賓

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Laravel5.1 框架Middleware中間件基本用法實例分析》,本文關(guān)鍵詞  Laravel5.1,框架,Middleware,中間件,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Laravel5.1 框架Middleware中間件基本用法實例分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Laravel5.1 框架Middleware中間件基本用法實例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章