在Laravel 5中使用多个身份验证防护时的重定向循环

蒂尔桑德斯

我正在尝试设置两个身份验证防护:(internal用于常规浏览器请求)和apiAJAX请求。api是默认的后卫,但现在我主要关注使internal-guard正常工作。

这是我的config / auth.php:

<?php

return [
    'defaults' => [
        'guard' => 'api',
        'passwords' => 'clients',
    ],

    'guards' => [
        'internal' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
        'api' => [
            'driver' => 'token',
            'provider' => 'clients',
        ],
    ],

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],
        'clients' => [
             'driver' => 'eloquent',
             'model' => App\Client::class,
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'email' => 'auth.emails.password',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];

这是我的routes.php:

<?php
Route::group([
    'domain' => 'internal.example.com',
    'middleware' => ['web', 'auth:internal']
], function () {
    Route::get('/', function () {
        return view('welcome');
    });
    Route::get('/home', 'HomeController@index');
});

Route::group([
    'domain' => 'internal.example.com',
    'middleware' => [ 'web']
], function () {
    Route::match(['get', 'post'], '/login', 'InternalAuth\InternalAuthController@login');
    Route::get('/logout', 'InternalAuth\InternalAuthController@logout');
});

这是InternalAuthController:

<?php

namespace App\Http\Controllers\InternalAuth;

use App\User;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ThrottlesLogins;
use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers;

class InternalAuthController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Registration & Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users, as well as the
    | authentication of existing users. By default, this controller uses
    | a simple trait to add these behaviors. Why don't you explore it?
    |
    */

    use AuthenticatesAndRegistersUsers, ThrottlesLogins;

    /**
     * Where to redirect users after login / registration.
     *
     * @var string
     */
    protected $redirectTo = '/';

    protected $guard = 'internal';

    /**
     * Create a new authentication controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest', ['except' => 'logout']);
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|confirmed|min:6',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        return User::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);
    }
}

对我来说似乎很好。但是,当我在浏览器中转到/,/ home或/ login时,最终会进入重定向循环。我想念的东西...有什么想法吗?

蒂尔桑德斯

/login指向InternalAuth\InternalAuthController@loginlogin()Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsersused by InternalAuth的方法,但它不负责返回视图或响应发布请求。这是一个工作getLoginpostLogin

因此,我需要在中更改此内容routes.php

Route::match(['get', 'post'], '/login', 'InternalAuth\InternalAuthController@login');

对此:

Route::get('/login', 'InternalAuth\InternalAuthController@getLogin');
Route::post('/login', 'InternalAuth\InternalAuthController@postLogin');

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

设置多个身份验证防护时出现Laravel重定向错误

在Laravel 5.3中通过身份验证时重定向

Laravel 身份验证无法重定向

Laravel:身份验证中间件中的多重防护

Laravel-当我尝试使用多重身份验证时获取错误的防护模型

在Laravel 4.2中使用Ajax,一旦用户通过身份验证,登录表单就不会重定向到预期的页面

如何解决cURL错误60:Facebook身份验证时在Laravel 5中使用SSL证书

laravel - 无法将多个身份验证重定向到不同的页面

Laravel 5 Socialite-动态更改身份验证重定向路径

Laravel 5身份验证中间件始终重定向到root或登录

Laravel 7 添加自定义身份验证:尝试登录时管理 url 重定向

Laravel - 重定向经过身份验证的用户

在laravel中的AppServiceProvider中使用身份验证

无法在Laravel 5中使用基本身份验证登录

如何在 Laravel 5 中使用 Codeception 在单元测试中模拟身份验证用户?

如何在Laravel 5中对多个表使用身份验证

登录页面在laravel 6中通过身份验证重定向到空白页面

Laravel-具有多重身份验证的未经身份验证的重定向问题

Laravel的多个身份验证

Laravel 5 中的重定向循环

未定义Laravel 5.8身份验证防护[api]

Laravel-如何获得对用户进行身份验证的防护?

Laravel-“未定义身份验证防护[admin]。”

如何在Laravel刀片模板中检查当前的身份验证防护及其访客?

使用新模型和防护的Laravel身份验证失败:未定义索引:模型

在laravel 5.2中使用默认身份验证路由对用户进行身份验证后设置会话数据

在 Laravel 中使用身份验证时出现“数组到字符串转换”错误

如何在laravel api中创建多个身份验证?

在Laravel / Fortify中使用API令牌进行身份验证