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

时间:2016-01-04 04:38:37

标签: php laravel middleware laravel-5.2

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

据我所知,Auth :: check()如果没有here的中间件网络,就行不通。

所以,我所做的是 -

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'
    ]);
});

AdminMiddleware.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');
    }
}

但是我收到了这个错误 -

enter image description here

当“返回Auth :: user(); ”在中间件中调用时,“返回Auth :: user();”正在其他地方工作(视图和控制器),但不像老版本的Laravel那样工作。

有人可以帮忙吗?

4 个答案:

答案 0 :(得分:3)

您可以做这样的事情,在需要的地方进行调整

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

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

    return $next($request);
}

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

答案 1 :(得分:0)

您还在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',
    ],
];

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

答案 2 :(得分:0)

你好@Cowboy和@lagbox, 感谢您试图提供帮助,不幸的是他们没有工作,但我已经解决了。

我通过运行 -

解决了这个问题
  

php artisan cache:clear

     

composer dump-autoload

     

php artisan clear-compiled

     

php artisan optimize

然后是中间件 -

<?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'
    ]);
});

答案 3 :(得分:0)

我有同样的问题。就我而言,我将在多重身份验证中面临这一问题。如果您在表中而不是id上使用具有不同主键名称的多重身份验证或什至是单一身份验证,则可能导致这种情况。

在Laravel中,用户表的默认主键为id。万一您将其更改为user_id或其他内容,则必须在模型中提及。否则,Laravel无法为用户创建会话,因此Auth::attempt()可以正常工作,而Auth::check()则不能。因此,请确保您已经在模型类中提到了这一点。

class User extends Authenticatable {
   $primaryKey = 'user_id';