laravel-middleware中间件使用方法

介绍

中间件提供了一种方便的机制过滤进入应用程序的 HTTP 请求。例如,Laravel 包含一个中间件,验证您的应用程序的用户身份验证。如果用户未被认证,中间件会将用户重定向到登录界面。然而,如果用户通过身份验证,中间件将进一步允许请求到应用程序中。

当然,除了身份认证以外,还可以编写另外的中间件来执行各种任务。例如:CORS 中间件可以负责为所有离开应用的响应添加合适的头部信息;日志中间件可以记录所有传入应用的请求。

Laravel 自带了一些中间件,包括身份验证、CSRF 保护等。所有这些中间件都位于 app/Http/Middleware 目录。

总结

要创建中间件,请执行以下过程

使用 artisan 命令创建中间件 php artisan make:middleware 中间件名.
在 app→Http 文件夹中的 kernel.php 中注册中间件
在创建的中间件中编写逻辑
将中间件分配给路由或控制器或全局注册中间件

示例A

1 创建middleware中间件

创建中间件的命令:

php artisan make:middleware GetCurrentTime

该命令会在 app/Http/Middleware 目录下创建一个新的GetCurrentTime类,

下面我们来演示一下中间件的简单使用
编写一个显示时间的middleware:

在这里插入图片描述

2 全局使用中间件

编写完成的中间件必须注册之后才能使用: 在app\Http\Kernel.php中注册

 protected $middleware = [
     \App\Http\Middleware\GetCurrentTime::class,
 ];

因为是全局所以没配置路由情况下显示如下:

在这里插入图片描述

3 路由中使用中间件

app\Http\Kernel.php中的protected $routeMiddleware中注册路由中间件

protected $routeMiddleware = [    
    'get_current_time'=>\App\Http\Middleware\GetCurrentTime::class,
];

显示如下:在路由后面使用链式加middleware(‘你定义的路由中间件的名称’);

Route::get('/', function () {
    return view('welcome');
})->middleware('get_current_time');

访问其他路由没有时间显示

在这里插入图片描述

3 在控制器中使用中间件

路由频率限制

在 Laravel 中该功能通过内置的 throttle 中间件来实现,该中间件接收两个参数,第一个是次数上限,第二个是指定时间段(单位:分钟):

Route::get('test','TestController@index')->middleware('throttle:3,1');

路径:laravel5\app\Http\Controllers\TestController.php

<?php
namespace App\Http\Controllers;
use PageCount\PageCountClass;
class TestController extends Controller
{
    public function __construct()
    {
        // 排除某些方法
        // return $this->middleware(['get_current_time'])->except('index');
        return $this->middleware('get_current_time');
    }
    public function index()
    {
        $pagecount = PageCountClass::pageCounts();
        return $pagecount;
    }
}

app\Http\Kernel.php中的protected $routeMiddleware中注册路由中间件

protected $routeMiddleware = [    
    'get_current_time'=>\App\Http\Middleware\GetCurrentTime::class,
];

在这里插入图片描述

4 中间件传递参数

通过用逗号分隔每个参数,可以将多个参数传递给中间件。

<?php
Route::get('admin/profile', function () {
  //action
})->middleware('auth:<role>,<age>,<country>');
 //<role>, <age>, <country> 这里应该被用户想要传递的任何参数替换。

这些参数在 $next 变量之后传递给中间件的 handle 函数

<?php
class RedirectIfSuperAdmin
{
    public function handle($request, Closure $next, $role, $age, $country)
    {   
        //使用解析参数的中间件逻辑
        return $next($request);
    }
}

5 Terminable 中间件响应后调用的方法

有时中间件可能需要在 HTTP 响应发送到浏览器之后处理一些工作。比如,Laravel 内置的「session」中间件会在响应发送到浏览器之后将会话数据写入存储器中。如果你在中间件中定义一个 terminate 方法,则会在响应发送到浏览器后自动调用:

<?php

namespace Illuminate\Session\Middleware;

use Closure;

class StartSession
{
    public function handle($request, Closure $next)
    {
        return $next($request);
    }

    public function terminate($request, $response)
    {
        // Store the session data...
    }
}

示例B - 中间件传递参数到控制器

php artisan make:middleware GetAuth.php

<?php

namespace App\Http\Middleware;

use Closure;

class GetAuth
{
    public function handle($request, Closure $next,$msg)
    {
        $info = [
            'parameter'=>'middleware传递参数只能是string类型',
            'qing'=>[
                'name'=>'xing',
                'msage'=>'虽然有些曲折但是我来了老弟!'
            ]
        ];
        # 两种方式那种都可以
        $request->attributes->add(['info' => $info]);
        // $request->merge(['info' => ['age'=>30]]);

        return $next($request);
    }
}

编写完成的中间件必须注册之后才能使用: 在app\Http\Kernel.php中注册

 protected $middleware = [
     \App\Http\Middleware\GetCurrentTime::class,
 ];

路由传递参数到中间件
Route::get('order', 'TxtController@createOrder')->middleware('getauth:parameter');

控制器

<?php
namespace App\Http\Controllers;

class TxtController extends Controller
{
    public function createOrder()
    {
        define('END_START', microtime(true));
        $time = END_START - LARAVEL_START;

        dd(request()->get('info'),$time);
    }

}

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知其黑、受其白

喝个咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值