中间件可以对请求进行过滤,这里可以利用中间件来验证用户是否登录,如果用户登录则可以继续执行原先想执行的操作,如果没登录则重定向到登录页面,让用户先登录。
一、定义中间件
通过 php artsian
make:middleware
命令 创建中间件,文件路径: app\Http\Middleware\CheckToken.php
php artisan make:middleware CheckToken
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class CheckToken
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next)
{
//在这里做一个判断,如果token不是 'my-secret-token',则重定向
if ($request->input('token') !== 'my-secret-token') {
return redirect('home');
}
return $next($request);
}
}
二、中间件的分类
<?php
namespace App\Http\Middleware;
use Closure;
class BeforeMiddleware
{
public function handle($request, Closure $next)
{
...
// 应用请求之前执行一些任务
return $next($request);
}
}
<?php
namespace App\Http\Middleware;
use Closure;
class AfterMiddleware
{
public function handle($request, Closure $next)
{
$response = $next($request);
// 应用请求之后执行一些任务
return $response;
}
}
三、中间件的使用
//在app\Http\Kernel.php中的$middleware内添加
protected $middleware = [
// \App\Http\Middleware\TrustHosts::class,
....
....
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
//这是之前定义的
\App\Http\Middleware\CheckToken::class,
];
//在app\Http\Kernel.php中的$middlewareGroups内添加
protected $middlewareGroups = [
'web' => [
....
],
'api' => [
....
],
'diy' =>[
//可以在web组和api组中添加,也可以自己diy一个
]
];
//路由中使用,RouteServiceProvider 默认将 web 和 api 中间件组自动应用到 routes/web.php 和 routes/api.php
Route::get('/u', function () {
})->middleware('diy');
protected $routeMiddleware = [
...,
'myself'=> \App\Http\Middleware\CheckToken::class,
];
Route::get('/user', function () {
//
})->middleware('myself');
相关视频教程推荐:Laravel 视频教程
以上就是laravel世界的卫士-中间件middleware的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章!