Laravel 5.6.28:身份验证中间件重定向到登录(未调用句柄)

时间:2018-10-10 06:29:25

标签: php laravel

在laravel中验证中间件以使用我的自定义防护对用户进行身份验证,但是每次我使用该中间件调用路由时,都会收到以下错误消息:

  

未定义路由[登录]。

现在,我只是试图确保正在调用中间件。这是我到目前为止所做的:

public function handle($request, Closure $next, $guard = null)
{ 
    return "hi";
    if (Auth::guard('api')->guest()) {
        if ($request->ajax() || $request->wantsJson()) {
            return response('Unauthorized.', 401);
        }

        return redirect()->guest('hi/login');
    }

    return $next($request);
}

以上是authenticate.php的处理方法。这是我的警卫代码

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'access_token',
        'provider' => 'users',
    ],
],
 'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\User::class,
    ],
],

路线: 这是我在其中具有实现身份验证的子组的路由组 中间件      Route::group(['prefix' => 'app'], function() use ($router) { }

这是我在Route::get('/subscribedcompanies','PromotionController@getFavoriteCompanies');上测试中间件的途径

我想添加的另一件事是我试图基于数据库中的access_token进行身份验证。我已更改登录控制器中的身份验证和凭据功能,如下所示:

protected function credentials(Request $request)
{
    return array_merge($request->header('authorization'));
}

public function authenticate(Request $request)
{
    $credentials = $request->header('authorization');

    if (Auth::attempt($credentials)) {
        // Authentication passed...
        return redirect()->intended('/');
    }
}

2 个答案:

答案 0 :(得分:1)

只需将您的登录路径命名为login Route::post('/login', 'LoginController@index')->name('login');

答案 1 :(得分:0)

感谢帮助人员。我将制作用于身份验证的自定义中间件。