当前位置: 首页 > 知识库问答 >
问题:

Laravel 5.2-使用Auth::check()在中间件中不起作用

施赞
2023-03-14

我正在尝试在我的Laravel 5.2应用程序中为不同类型的用户制作一个中间件。所以,我正在做的是为不同的用户制作不同的中间件。

据我所知,如果不考虑中间件web,Auth::check()将无法工作。

所以,我所做的是-

routes.php

Route::group(['middleware' => ['web','admin']], function ()
{
    //suspend, activate, delete
    Route::get('users', [
        'uses'          => 'AdminController@users',
        'as'            => 'users'
    ]);

    //Edit,activate,suspend, delete
    Route::get('articles', [
        'uses'          => 'AdminController@articles',
        'as'            => 'articles'
    ]);
});

管理iddleware.php

<?php

namespace App\Http\Middleware;

use Closure;
use Auth;

class AdminMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if (Auth::check())
        {
            return "asd";
            //return Auth::user();
            //return redirect('home');
        }
        else
        {
            return redirect('login');
        }

        //now return the valid request
        return $next($request);
    }
}

Kernel.php

protected $routeMiddleware = [
    'auth'          => \App\Http\Middleware\Authenticate::class,
    'admin'         => \App\Http\Middleware\AdminMiddleware::class,
    'user'          => \App\Http\Middleware\UserMiddleware::class,
    'auth.basic'    => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'guest'         => \App\Http\Middleware\RedirectIfAuthenticated::class,
    'throttle'      => \Illuminate\Routing\Middleware\ThrottleRequests::class,
];

AdminController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use App\Http\Requests;
use App\Http\Controllers\Controller;

class AdminController extends Controller
{
    public function users()
    {
        return view('admin.users');
    }

    public function articles()
    {
        return view('admin.articles');
    }
}

但我得到了这个错误-

在中间件内部调用“return Auth::user();”时,“return Auth::user();”在其他位置(视图和控制器)工作,但与旧版本的Laravel不同。

有谁能帮忙吗?

共有3个答案

邹星火
2023-03-14

您也在web组中添加了路由,所以请确保您的内核文件应该包含以下中间件组。

/**
 * The application's route middleware groups.
 *
 * @var array
 */
protected $middlewareGroups = [
    'web' => [
        \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,
    ],

    'api' => [
        'throttle:60,1',
    ],
];

由于会话而导致的错误。确保内核文件包含会话中间件。

裴嘉许
2023-03-14

嗨@Cowboy和@lagbox,谢谢你的帮助,不幸的是他们不工作,但我已经解决了。

我通过跑步解决了这个问题-

php artisan缓存:清除

作曲家转储-自动加载

php artisan clear已编译

php artisan优化

然后中间件-

<?php

namespace App\Http\Middleware;

use Closure;
use Auth;

class AdminMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if (Auth::check())
        {
            if(strcmp( "admin" , Auth::user()->user_type ) != 0 )
                return redirect('home');
            else
                return $next($request);
        }
        else
        {
            return redirect('login');
        }

        //now return the valid request
        //return $next($request);
    }
}

路线-

Route::group(['middleware' => ['web','admin']], function ()
{
    //suspend, activate, delete
    Route::get('users', [
        'uses'          => 'AdminController@users',
        'as'            => 'users'
    ]);

    //Edit,activate,suspend, delete
    Route::get('articles', [
        'uses'          => 'AdminController@articles',
        'as'            => 'articles'
    ]);
});
长孙沈义
2023-03-14

你可以这样做,根据需要进行调整

public function handle($request, Closure $next)
{
    $user = $request->user();

    if (! $user || $user->user_type != 'admin') {
        return redirect('login');
    }

    return $next($request);
}

您收到的错误来自于您没有从中间件返回响应对象的事实。VerifyCsrfToken中间件试图将cookie添加到它通过将请求向下传递到管道而获得的响应中。在这种情况下,它不是获取响应对象,而是获取字符串或User,因为在中间件中返回了字符串或User

 类似资料:
  • 问题内容: 首先,我创建了一个表,例如 然后在该表中插入值 MySQL没有显示错误,它接受了值。 问题答案: 如果您使用MySQL 8.0.15或更早版本,则MySQL参考手册会说: 该CHECK子句已解析,但所有存储引擎均将其忽略。 尝试触发… 希望能有所帮助。

  • 我已经创建了一个新的中间件名称Adminpanel 和注册中间件 和路线 }); 但当我运行时,它要求我尝试获取非对象的属性,这意味着我不能在这里访问Auth类,有人能告诉我错误是什么以及如何在中间件中访问Auth Facade吗。 这是我的身份验证码 谢谢

  • 问题内容: 众所周知,Laravel 5.2是几天前发布的。我正在尝试这个新版本。我在CLI上使用以下命令创建了一个新项目: 根据Authentication Quickstart的文档 ,我遵循以下命令来搭建身份验证的路由和视图: 工作正常。注册工作正常。但是我在登录时遇到问题。登录后,我在route.php文件中进行了以下测试: 是返回,也和没有适当工作。我通过制作新项目一次又一次尝试了两次,

  • 我在flutter应用程序中使用Firebase的电话身份验证。一切正常,但OTP的自动验证不起作用。用户必须手动输入OTP。在网上查看,似乎必须更短才能正常工作。 目前是

  • 和启动类: 这很好,但是正如您所看到的,RequestCultureMiddleware没有实现接口或基类/抽象类。您只需要记住,在定义中间件时创建接收下一个中间件的构造函数,还需要创建一个专门名为“InvokeAsync”的方法,并将“HttpContext”作为参数。 我想找份合同...基类或接口,猜猜看,我们有“imiddleware”,它是“Microsoft.aspnetcore.htt

  • nav.component.ts app.module.ts app.component.ts