婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

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

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

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

為什么要使用中間件?

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

1 使用中間件

1.1 創建中間件

咱創建中間件是使用artisan控制臺的:

php artisan make:middleware TestMiddleware

創建好后位于:app/Http/Middleware

1.2 解讀中間件

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

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”函數 這個函數呢接受兩個參數

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

如果你還是不太懂的話 沒關系 咱上實例

1.3 編寫中間件

  public function handle($request, Closure $next)
  {
    // 如果傳入的id參數等于0 就跳轉到首頁。
    if ($request->input('id') == 0){
      return redirect('/');
    }
    // id參數不等于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,
    // 把我們創建的middleware注冊到這里
    'test' => \App\Http\Middleware\TestMiddleware::class,
  ];

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

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 時會返回首頁。

更多關于Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

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

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

標簽:鎮江 南陽 寶雞 湛江 婁底 黃南 銅川 宜賓

巨人網絡通訊聲明:本文標題《Laravel5.1 框架Middleware中間件基本用法實例分析》,本文關鍵詞  Laravel5.1,框架,Middleware,中間件,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel5.1 框架Middleware中間件基本用法實例分析》相關的同類信息!
  • 本頁收集關于Laravel5.1 框架Middleware中間件基本用法實例分析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 建水县| 安康市| 大同市| 全州县| 阿巴嘎旗| 齐河县| 科技| 房山区| 东平县| 临潭县| 黑山县| 枣阳市| 峡江县| 永福县| 涡阳县| 巴彦淖尔市| 平塘县| 伊宁市| 南平市| 洛南县| 错那县| 玉田县| 姜堰市| 天柱县| 青州市| 徐州市| 江城| 上杭县| 莱州市| 汽车| 郁南县| 乌拉特中旗| 鹿泉市| 津市市| 洞头县| 孝昌县| 巧家县| 崇州市| 吉隆县| 宁陵县| 清流县|