ご覧いただきありがとうございます。
https://qiita.com/hitotch/items/45c70110291f725d87c4
こちらのページを参考にマルチ認証を実装しようとしています。
http://localhost:8000/register/admin
にアクセスして管理者ユーザを登録しようとしたところ
Target class [App\Http\Controllers\Auth\Request] does not exist.
のエラーが出ました。
RedirectIfAuthenticated.phpの34行目でエラーが出ているので該当ファイルを確認したところ
use Illuminate\Http\Request;
が既に書かれていました。
PHP
1<?php 2 3namespace App\Http\Middleware; 4 5use App\Providers\RouteServiceProvider; 6use Closure; 7use Illuminate\Http\Request; 8use Illuminate\Support\Facades\Auth; 9 10class RedirectIfAuthenticated 11{ 12 /** 13 * Handle an incoming request. 14 * 15 * @param \Illuminate\Http\Request $request 16 * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next 17 * @param string|null ...$guards 18 * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse 19 */ 20 public function handle(Request $request, Closure $next, ...$guards) 21 { 22 $guards = empty($guards) ? [null] : $guards; 23 24 foreach ($guards as $guard) { 25 if ($guard == "admin" && Auth::guard($guard)->check()) { 26 return redirect(route('admin-home')); 27 } 28 29 if(Auth::guard($guard)->check()){ 30 return redirect(RouteServiceProvider::HOME); 31 } 32 } 33 34 return $next($request); 35 } 36} 37
LoginControllerのコードは以下になります
PHP
1<?php 2 3namespace App\Http\Controllers\Auth; 4 5use App\Http\Controllers\Controller; 6use App\Providers\RouteServiceProvider; 7use Illuminate\Http\Request; 8use Illuminate\Support\Facades\Auth; 9use Illuminate\Foundation\Auth\AuthenticatesUsers; 10 11class LoginController extends Controller 12{ 13 /* 14 |-------------------------------------------------------------------------- 15 | Login Controller 16 |-------------------------------------------------------------------------- 17 | 18 | This controller handles authenticating users for the application and 19 | redirecting them to your home screen. The controller uses a trait 20 | to conveniently provide its functionality to your applications. 21 | 22 */ 23 24 use AuthenticatesUsers; 25 26 /** 27 * Where to redirect users after login. 28 * 29 * @var string 30 */ 31 protected $redirectTo = RouteServiceProvider::HOME; 32 33 /** 34 * Create a new controller instance. 35 * 36 * @return void 37 */ 38 public function __construct() 39 { 40 $this->middleware('guest')->except('logout'); 41 $this->middleware('guest:admin')->except('logout'); 42 } 43 44 /** 45 * 管理者ログイン用 46 */ 47 public function showAdminLoginForm(){ 48 return view('auth.login',['authgroup' => 'admin']); 49 } 50 51 public function adminLogin(Request $request){ 52 $this->validate($request, [ 53 'email' => 'required|email', 54 'password' => 'required|min:8' 55 ]); 56 57 if(method_exists($this, 'hasTooManyLoginAttempts') && 58 $this->hasTooManyLoginAttempts($request)){ 59 $this->fireLockoutEvent($request); 60 61 return $this->sendLockoutResponse($request); 62 } 63 64 if(Auth::guard('admin')->attempt(['email' => $request->email,'password' => $request->password],$request->get('remember'))){ 65 return redirect()->intended('/admin'); 66 } 67 68 69 $this->incrementLoginAttempt($request); 70 71 return back()->withInput($request->only('email','remember')); 72 } 73 74} 75
他に確認する箇所はどこでしょうか?
回答1件
あなたの回答
tips
プレビュー