ご覧いただきありがとうございます。
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
<?php namespace App\Http\Middleware; use App\Providers\RouteServiceProvider; use Closure; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class RedirectIfAuthenticated { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next * @param string|null ...$guards * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse */ public function handle(Request $request, Closure $next, ...$guards) { $guards = empty($guards) ? [null] : $guards; foreach ($guards as $guard) { if ($guard == "admin" && Auth::guard($guard)->check()) { return redirect(route('admin-home')); } if(Auth::guard($guard)->check()){ return redirect(RouteServiceProvider::HOME); } } return $next($request); } }
LoginControllerのコードは以下になります
PHP
<?php namespace App\Http\Controllers\Auth; use App\Http\Controllers\Controller; use App\Providers\RouteServiceProvider; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use Illuminate\Foundation\Auth\AuthenticatesUsers; 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; /** * Where to redirect users after login. * * @var string */ protected $redirectTo = RouteServiceProvider::HOME; /** * Create a new controller instance. * * @return void */ public function __construct() { $this->middleware('guest')->except('logout'); $this->middleware('guest:admin')->except('logout'); } /** * 管理者ログイン用 */ public function showAdminLoginForm(){ return view('auth.login',['authgroup' => 'admin']); } public function adminLogin(Request $request){ $this->validate($request, [ 'email' => 'required|email', 'password' => 'required|min:8' ]); if(method_exists($this, 'hasTooManyLoginAttempts') && $this->hasTooManyLoginAttempts($request)){ $this->fireLockoutEvent($request); return $this->sendLockoutResponse($request); } if(Auth::guard('admin')->attempt(['email' => $request->email,'password' => $request->password],$request->get('remember'))){ return redirect()->intended('/admin'); } $this->incrementLoginAttempt($request); return back()->withInput($request->only('email','remember')); } }
他に確認する箇所はどこでしょうか?
まだ回答がついていません
会員登録して回答してみよう