1

我运行 laravel jetstream 并设置为 livewire 而不是 vue。我通常使用 auth ui 并自定义登录

App -> Http -> 控制器 -> auth -> LoginController

在这个 LoginController 中,我像这样自定义这个重定向

 protected function authenticated(Request $request, $user)
{
    if ( $user->isUser() ) {// do your margic here
        return redirect()->route('user_dashboard');
    }
    elseif ($user->isSarpras()) {
        return redirect()->route('admin_sarpras_dashboard');
    }
}

但是在 laravel jetstream iam 上找不到 Controller->auth 。如何使用 laravel jetstream 最好地管理登录和创建多个登录?

4

2 回答 2

2

在这里找到:https ://talltips.novate.co.uk/laravel/laravel-8-conditional-login-redirects

  1. 在 app\Http 下创建一个名为 Responses 的文件夹
  2. 创建一个文件 LoginResponse.php
<?php

namespace App\Http\Responses;

use Illuminate\Support\Facades\Auth;
use Laravel\Fortify\Contracts\LoginResponse as LoginResponseContract;

class LoginResponse implements LoginResponseContract
{

    public function toResponse($request)
    {
        
        // below is the existing response
        // replace this with your own code
        // the user can be located with Auth facade
        
        return $request->wantsJson()
                    ? response()->json(['two_factor' => false])
                    : redirect()->intended(config('fortify.home'));
    }

}
  1. 让 Laravel 使用我们新的响应类

这个新类现在取代了之前由 Fortify 注册的 Singleton。

编辑 app\Providers 文件夹中的 JetstreamServiceProvider;

在 boot 方法中,添加对新响应类的引用。当登录完成(并且用户实际上已通过身份验证)时,您的新响应将被调用。

    public function boot()
    {
        $this->configurePermissions();

        Jetstream::deleteUsersUsing(DeleteUser::class);

        // register new LoginResponse
        $this->app->singleton(
            \Laravel\Fortify\Contracts\LoginResponse::class,
            \App\Http\Responses\LoginResponse::class
        );
    }

两因素身份验证

如果您将 2FA 与 Jetstream 一起使用,您还需要捕获 TwoFactorLoginResponse。使用相同的方法;

        // register new TwofactorLoginResponse
        $this->app->singleton(
            \Laravel\Fortify\Contracts\TwoFactorLoginResponse::class,
            \App\Http\Responses\LoginResponse::class
        );

如果您希望使用 2FA 登录的用户有不同的行为,您可以返回相同的响应,或者创建额外的响应。

于 2021-04-27T13:02:19.237 回答
0

Jetstream使用Fortify进行身份验证。

目前,Fortify 无法自定义重定向。

这里有一个开放的问题要求这种行为:https ://github.com/laravel/fortify/issues/77

很有可能很快就会添加!

编辑

现在您可以通过以下方式自定义重定向config/fortify.php

'redirects' => [
    'login' => 'dashboard',
    'logout' => 'home',
    'password-confirmation' => null,
    'register' => 'dashboard',
    'email-verification' => null,
    'password-reset' => null,
],

如果您需要对此行为进行高级定制,请查看此处的文档

于 2020-09-25T04:01:20.327 回答