Die folgende Methode funktioniert hervorragend:
Kopieren Sie alle Routen von /vendor/laravel/framework/src/Illuminate/Routing/Router.php
und fügen Sie sie ein web.php
und kommentieren oder löschen Sie sie Auth::routes()
.
Richten Sie dann eine Bedingung ein, um die Registrierung von .env zu aktivieren und zu deaktivieren. Dupliziere die 503.blade.php
Datei in views/errors
und erstelle eine 403 verbotene oder was auch immer du willst.
Fügen Sie ALLOW_USER_REGISTRATION=
.env hinzu und steuern Sie die Benutzerregistrierung, indem Sie den Wert auf true oder false setzen.
Jetzt haben Sie die volle Kontrolle über Routen und Vendor-Dateien bleiben unberührt.
web.php
//Auth::routes();
// Authentication Routes...
Route::get('login', 'Auth\LoginController@showLoginForm')->name('login');
Route::post('login', 'Auth\LoginController@login');
Route::post('logout', 'Auth\LoginController@logout')->name('logout');
// Registration Routes...
if (env('ALLOW_USER_REGISTRATION', true))
{
Route::get('register', 'Auth\RegisterController@showRegistrationForm')->name('register');
Route::post('register', 'Auth\RegisterController@register');
}
else
{
Route::match(['get','post'], 'register', function () {
return view('errors.403');
})->name('register');
}
// Password Reset Routes...
Route::get('password/reset', 'Auth\ForgotPasswordController@showLinkRequestForm')->name('password.request');
Route::post('password/email', 'Auth\ForgotPasswordController@sendResetLinkEmail')->name('password.email');
Route::get('password/reset/{token}', 'Auth\ResetPasswordController@showResetForm')->name('password.reset');
Route::post('password/reset', 'Auth\ResetPasswordController@reset');
Dies ist eine Kombination einiger früherer Antworten, insbesondere von Rafal G. und Daniel Centore.