web-dev-qa-db-ja.com

Laravel 5.4ログイン後のカスタムURLへのリダイレクト

私はLaravel Framework 5.4.10を使用しており、通常の認証を使用しています。

php artisan make:auth

提供します。アプリ全体を保護し、ログイン後にユーザーを/ themesにリダイレクトしたい。

ForgotPasswordController.php、LoginController.php、RegisterController.php、ResetPasswordController.phpの4つのコントローラーがあります。この行を最後の3行に編集しました。

protected $redirectTo = '/themes';

これは私のroutes/web.phpの最初の行です:

Auth::routes();

Controller.phpにこの関数を追加しました:

    public function __construct()
    {
        $this->middleware('auth');

    }

App/Http/Middleware/RedirectIfAuthenticated.phpを編集したので、ハンドル関数は次のようになります。

public function handle($request, Closure $next, $guard = null)
{
    if (Auth::guard($guard)->check()) {
        return redirect('/themes');
    }

    return $next($request);
}

「ログイン」ボタンをクリックすると、「/テーマ」ではなく「/」にリダイレクトされることを除いて、すべて問題ありません。コントローラで認証を必要としない場合(Controller.phpファイルには__contruct関数はありません)、ログイン時にリダイレクトされます。私は何を間違えていますか?

31
ivanacorovic

それは私が現在働いているもの、偶然です。

また、次の行をLoginControllerに追加する必要があります

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;

use Illuminate\Foundation\Auth\AuthenticatesUsers;

use Illuminate\Http\Request;

class LoginController extends Controller
{
/*
|--------------------------------------------------------------------------
| Login Controller
|--------------------------------------------------------------------------
|
| This controller handles authenticating users for the application and
| redirecting them to your home screen. The controller uses a trait
| to conveniently provide its functionality to your applications.
|
*/

use AuthenticatesUsers;


protected function authenticated(Request $request, $user)
{
if ( $user->isAdmin() ) {// do your margic here
    return redirect()->route('dashboard');
}

 return redirect('/home');
}
/**
 * Where to redirect users after login.
 *
 * @var string
 */
//protected $redirectTo = '/admin';

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

AuthenticatesUsers特性を見ると、sendLoginResponseメソッドで$this->redirectPath()が呼び出されていることがわかります。このメソッドを見ると、redirectToがメソッドまたは変数のいずれかであることがわかります。

これは私が今私の認証コントローラーに持っているものです。

public function redirectTo() {
    $user = Auth::user();
    switch(true) {
        case $user->isInstructor():
            return '/instructor';
        case $user->isAdmin():
        case $user->isSuperAdmin():
            return '/admin';
        default:
            return '/account';
    }
}
9
plexus

AuthenticatesUsersトレイトを使用して行った方法。

\App\Http\Controllers\Auth\LoginController.php

このメソッドをそのコントローラーに追加します。

/**
 * Check user's role and redirect user based on their role
 * @return 
 */
public function authenticated()
{
    if(auth()->user()->hasRole('admin'))
    {
        return redirect('/admin/dashboard');
    } 

    return redirect('/user/dashboard');
}
8
Amirul

リダイレクトするルートに$ redirectTo値を設定する必要があります

$this->redirectTo = route('dashboard');

authControllerコンストラクター内。

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

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

Laravel documentation に従って、app/Http/Controllers/Auth/LoginController.phpに次のメソッドを作成します。

protected function redirectTo()
{
    $user=Auth::user();

    if($user->account_type == 1){
        return '/admin';
    }else{
        return '/home';
    }

}

データベースからユーザー情報を取得するには、「Illuminate\Support\Facades\Auth;」を使用しました。

0
Giuseppe Muci

loginControllerにメソッドを追加できます。トップのuse App\User;行を追加します。この追加メソッドの後、wkwkwkwkwが動作しますが、ビューadminおよびユーザーに{{ csrf_field() }}を追加する必要があります

protected function authenticated(Request $request, $user){

$user=User::where('email',$request->input('email'))->pluck('jabatan');
$c=" ".$user." ";
$a=strcmp($c,' ["admin"] ');

if ($a==0) {
    return redirect('admin');

}else{
    return redirect('user');

}}
0