在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('/');
}
}
答案 0 :(得分:1)
只需将您的登录路径命名为login
Route::post('/login', 'LoginController@index')->name('login');
答案 1 :(得分:0)
感谢帮助人员。我将制作用于身份验证的自定义中间件。