質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.32%

laravel マルチログイン機能がうまくいかない

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 319

sus

score 7

前提・実現したいこと

現在laravelでマルチログイン機能を作っています。
教員用のログイン、登録機能を実装中に以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

Target class [Professor\LoginController] does not exist.

route/web.php

<?php
use Illuminate\Support\Facades\Route;
use App\Http\Controllers\Professor\LoginController;

Auth::routes();

/*
|--------------------------------------------------------------------------
| userログイン前
|--------------------------------------------------------------------------
|
*/
Route::get('/', function () {
    return view('welcome');
});
/*
|--------------------------------------------------------------------------
| userログイン後
|--------------------------------------------------------------------------
|
*/
Route::group(['middleware'=> 'auth:user'], function(){
    Route::get('/home', [App\Http\Controllers\HomeController::class, 'index'])->name('home');
});
/*
|--------------------------------------------------------------------------
| professorログイン前
|--------------------------------------------------------------------------
|
*/

Auth::routes();

Route::group(['prefix' => 'professor'], function() {
    Route::get('/', function () { return redirect('home'); });
    Route::get('/login', 'Professor\LoginController@showLoginForm')->name('professor.login');
    Route::get('/login', [LoginController::class, 'showLoginForm'])->name('Professor.login');
    Route::get('/register', 'Professor\LoginController@showRegisterForm')->name('professor.register');
    Route::post('/login', 'Professor\LoginController@login');
});


/*
|--------------------------------------------------------------------------
| professorログイン後
|--------------------------------------------------------------------------
|
*/
Route::group(['prefix' => 'professor', 'middleware' => 'auth:professor'], function() {
    Route::post('logout',[App\Http\Controllers\LoginController::class, 'logout'])->name('professor.logout');
    Route::get('/home', [App\Http\Controllers\HomeController::class, 'index'])->name('home');
});

App/Http/Controllers/Professor/LoginController.php

<?php

namespace App\Http\Controllers\Professor;

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
{

    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:professor')->except('logout');
    }



    public function showLoginForm()
    {
        return view('professor.login');  
    }

    protected function guard()
    {
        return Auth::guard('professor');  
    }

    public function logout(Request $request)
    {
        // Auth::guard('professor')->logout();  
        $request->session()->flush();
        $request->session()->regenerate();

        return redirect('/professor/login');  
    }
}

App/Http/Controllers/Professor/HomeController.php

<?php

namespace App\Http\Controllers\Professor;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;

class HomeController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('auth:professor');
    }

    /**
     * Show the application dashboard.
     *
     * @return \Illuminate\Contracts\Support\Renderable
     */
    public function index()
    {
        return view('professor:home');
    }
}

config/auth.php

<?php

return [

    /*
    |--------------------------------------------------------------------------
    | Authentication Defaults
    |--------------------------------------------------------------------------
    |
    | This option controls the default authentication "guard" and password
    | reset options for your application. You may change these defaults
    | as required, but they're a perfect start for most applications.
    |
    */

    'defaults' => [
        'guard' => 'user',
        'passwords' => 'users',
    ],

    /*
    |--------------------------------------------------------------------------
    | Authentication Guards
    |--------------------------------------------------------------------------
    |
    | Next, you may define every authentication guard for your application.
    | Of course, a great default configuration has been defined for you
    | here which uses session storage and the Eloquent user provider.
    |
    | All authentication drivers have a user provider. This defines how the
    | users are actually retrieved out of your database or other storage
    | mechanisms used by this application to persist your user's data.
    |
    | Supported: "session", "token"
    |
    */

    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
            'hash' => false,
        ],
        'user' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
        'professor' => [ //追加
            'driver' => 'session', //追加
            'provider' => 'professors', //追加
        ],
    ],

    /*
    |--------------------------------------------------------------------------
    | User Providers
    |--------------------------------------------------------------------------
    |
    | All authentication drivers have a user provider. This defines how the
    | users are actually retrieved out of your database or other storage
    | mechanisms used by this application to persist your user's data.
    |
    | If you have multiple user tables or models you may configure multiple
    | sources which represent each model / table. These sources may then
    | be assigned to any extra authentication guards you have defined.
    |
    | Supported: "database", "eloquent"
    |
    */

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\Models\User::class,
        ],
        'professors' => [ //追加
            'driver' => 'eloquent', //追加
            'model' => App\Models\Professor::class, //追加
        ],

        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

    /*
    |--------------------------------------------------------------------------
    | Resetting Passwords
    |--------------------------------------------------------------------------
    |
    | You may specify multiple password reset configurations if you have more
    | than one user table or model in the application and you want to have
    | separate password reset settings based on the specific user types.
    |
    | The expire time is the number of minutes that the reset token should be
    | considered valid. This security feature keeps tokens short-lived so
    | they have less time to be guessed. You may change this as needed.
    |
    */

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
            'throttle' => 60,
        ],
        'professors' => [ //追加
            'provider' => 'professors', //追加
            'table' => 'password_resets', //追加
            'expire' => 60, //追加
        ],
    ],

    /*
    |--------------------------------------------------------------------------
    | Password Confirmation Timeout
    |--------------------------------------------------------------------------
    |
    | Here you may define the amount of seconds before a password confirmation
    | times out and the user is prompted to re-enter their password via the
    | confirmation screen. By default, the timeout lasts for three hours.
    |
    */

    'password_timeout' => 10800,

];

試したこと

コントローラのnamespace、ルーティングのスペルなどチェックしましたが解決しませんでした。laravel 8.xからルーティングの記載方法が変わった事を考慮して書き換えてみましたが変化なかったです。
どこに原因があるか教えていただけたら嬉しいです。よろしくお願いします。

補足情報(FW/ツールのバージョンなど)

laravel 8.4.0
PHP 7.4.10

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

+1

Route::group(['prefix' => 'professor'], function() {
    Route::get('/', function () { return redirect('home'); });
    Route::get('login',[App\Http\Controllers\Professor\LoginController::class, 'showLoginForm'])->name('professor.login');
    Route::post('login',[App\Http\Controllers\Professor\LoginController::class, 'login']);
    Route::get('register',[App\Http\Controllers\Professor\RegisterController::class, 'showRegisterForm'])->name('professor.register');

});


こちらで解決できました

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.32%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る