Php 使用auth laravel 5.7自定义登录和注册

Php 使用auth laravel 5.7自定义登录和注册,php,laravel,Php,Laravel,我正在尝试用Laravel 5.7创建第一个项目 在这个项目中,我有三个不同的区域,有三种不同的登录方式(例如,用户登录、管理员登录、技术人员登录)。 现在,我想自定义第一次登录(url、html、输入、类、db表、db列ecc…),但我不知道怎么做 第一次登录的URL是website.com/public/users 我的表格是: CREATE TABLE `gf_users` ( `gf_id` int(11) NOT NULL, `gf_name` text NOT NULL,

我正在尝试用Laravel 5.7创建第一个项目

在这个项目中,我有三个不同的区域,有三种不同的登录方式(例如,用户登录、管理员登录、技术人员登录)。

现在,我想自定义第一次登录(url、html、输入、类、db表、db列ecc…),但我不知道怎么做

第一次登录的URL
website.com/public/users

我的表格是:

CREATE TABLE `gf_users` (
  `gf_id` int(11) NOT NULL,
  `gf_name` text NOT NULL,
  `gf_email` varchar(200) NOT NULL,
  `gf_password` varchar(300) NOT NULL,
) 
我搜索了很多,根据我找到的信息,我试着做到这一点:

config/auth.php

return [

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

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

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    ],

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\GFUsers::class
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];
// Authentication Routes
Route::get('users', 'Auth\NewLoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\NewLoginController@checklogin');
Route::post('logout', 'Auth\NewLoginController@logout')->name('logout');
// Registration Routes
Route::get('users/registration', 'Auth\RegisterController@showRegistrationFormUsers')->name('register');
Route::post('users/registration', 'Auth\RegisterController@register');
<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\Request;

class LoginController extends Controller
{

    use AuthenticatesUsers;
    protected $redirectTo = '/users/details';

    public function __construct()
    {
        $this->middleware('guest')->except('logout');
    }
    
    
    public function showLoginFormUsers(){
        return view('users.login');
    }
    
    public function username(){
        return 'gf_email';
    }
    
    function checklogin(Request $request){
        
        $this->validate($request, [
            'input-email' => 'required', 
            'input-password' => 'required',
        ]);
        
        $user_data = array(
            'gf_email'  => $request->get('input-email'),
            'password' => $request->get('input-password')
        );
        
        if(!Auth::attempt($user_data)){
            return redirect('users');
        }
        
        if ( Auth::check() ) {
            return redirect('users/details');
        }
    }
    
    function logout(){
        Auth::logout();
        return redirect('users');
    }

}
<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Notifiable;
    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';
    public $timestamps = false; 
    
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password', 'gf_remember_token',
    ];
    
    /**
     * Get the password for the user.
     *
     * @return string
     */
    public function getAuthPassword(){
        return $this->gf_password;
    }
    
    /**
     * Get the token value for the "remember me" session.
     *
     * @return string
     */
    public function getRememberToken()
    {
        return $this->gf_remember_token;
    }
    
    /**
     * Set the token value for the "remember me" session.
     *
     * @param  string  $value
     * @return void
     */
    public function setRememberToken($value)
    {
        $this->gf_remember_token = $value;
    }
    
    /**
     * Get the column name for the "remember me" token.
     *
     * @return string
     */
    public function getRememberTokenName()
    {
        return 'gf_remember_token';
    }
    
    /**
     * Get the e-mail address where password reminders are sent.
     *
     * @return string
     */
    public function getReminderEmail()
    {
        return $this->gf_email;
    }
}
web.php

Route::get('users', 'Auth\LoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\LoginController@login');
namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class GFUsers extends Authenticatable
{
    use Notifiable;

    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password'
    ];


    public function getAuthPassword(){
        return $this->gf_password;
    }
}
<form method="POST" action="{{ asset('/users') }}">
@csrf
  <div class="form-group">
    <input type="email" class="form-control" name="gf_email" id="gf_email" placeholder="Email" required>
  </div>
  <div class="form-group">
    <input type="password" class="form-control" name="gf_password" id="gf_password" placeholder="Password" required>
  </div>
  <button type="submit" class="btn btn-primary">LOGIN</button>
</form>
LoginController.php

public function showLoginFormUsers(){
   return view('users.login');
}

public function username(){
   return 'gf_email';
}
<form method="POST" action="{{ asset('/users') }}">
@csrf
  <div class="form-group">
    <input type="email" class="form-control" name="input-email" id="input-email" placeholder="Email" required>
  </div>
  <div class="form-group">
    <input type="password" class="form-control" name="input-password" id="input-password" placeholder="Password" required>
  </div>
  <button type="submit" class="btn btn-primary">LOGIN</button>
</form>
GFUsers.php

Route::get('users', 'Auth\LoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\LoginController@login');
namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class GFUsers extends Authenticatable
{
    use Notifiable;

    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password'
    ];


    public function getAuthPassword(){
        return $this->gf_password;
    }
}
<form method="POST" action="{{ asset('/users') }}">
@csrf
  <div class="form-group">
    <input type="email" class="form-control" name="gf_email" id="gf_email" placeholder="Email" required>
  </div>
  <div class="form-group">
    <input type="password" class="form-control" name="gf_password" id="gf_password" placeholder="Password" required>
  </div>
  <button type="submit" class="btn btn-primary">LOGIN</button>
</form>
login.blade.php

Route::get('users', 'Auth\LoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\LoginController@login');
namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class GFUsers extends Authenticatable
{
    use Notifiable;

    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password'
    ];


    public function getAuthPassword(){
        return $this->gf_password;
    }
}
<form method="POST" action="{{ asset('/users') }}">
@csrf
  <div class="form-group">
    <input type="email" class="form-control" name="gf_email" id="gf_email" placeholder="Email" required>
  </div>
  <div class="form-group">
    <input type="password" class="form-control" name="gf_password" id="gf_password" placeholder="Password" required>
  </div>
  <button type="submit" class="btn btn-primary">LOGIN</button>
</form>

@csrf
登录
如果我编译表单并点击登录按钮,这会刷新页面,但我不知道它是否有效

1。程序正确吗?
2。有错误吗
3。我忘了什么吗?

4。注册怎么办?

您最好不要为用户、管理员和技术人员制作不同的表格。他们都是用户。在一个表中,仅使用不同属性(例如-角色、状态、is_admin、is_user…)。

config/auth.php:

return [

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

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

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],

        'gfuser' => [
            'driver' => 'session',
            'provider' => 'gfuser',
        ],
    ],

    'providers' => [
        'gfuser' => [
            'driver' => 'eloquent',
            'model' => App\GFUsers::class
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];
登录控制器

Auth::guard('gfuser')->login($user); //array data with username and password
OR
if (Auth::guard('gfuser')->attempt(['username' => $username, 'password' => $password]) {//Redirect to dashboard}

经过长时间的研究,我找到了解决办法。我希望这能帮助其他人。
我已经定制了:id、用户名、密码和表中的记忆令牌,以及User.php、LoginController.php文件。

==表==:

CREATE TABLE `gf_users` (
  `gf_id` int(11) NOT NULL,
  `gf_name` text NOT NULL,
  `gf_email` varchar(200) NOT NULL,
  `gf_password` varchar(300) NOT NULL,
  `gf_remember_token` varchar(300) NOT NULL
) 
web.php

return [

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

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

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    ],

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\GFUsers::class
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];
// Authentication Routes
Route::get('users', 'Auth\NewLoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\NewLoginController@checklogin');
Route::post('logout', 'Auth\NewLoginController@logout')->name('logout');
// Registration Routes
Route::get('users/registration', 'Auth\RegisterController@showRegistrationFormUsers')->name('register');
Route::post('users/registration', 'Auth\RegisterController@register');
<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\Request;

class LoginController extends Controller
{

    use AuthenticatesUsers;
    protected $redirectTo = '/users/details';

    public function __construct()
    {
        $this->middleware('guest')->except('logout');
    }
    
    
    public function showLoginFormUsers(){
        return view('users.login');
    }
    
    public function username(){
        return 'gf_email';
    }
    
    function checklogin(Request $request){
        
        $this->validate($request, [
            'input-email' => 'required', 
            'input-password' => 'required',
        ]);
        
        $user_data = array(
            'gf_email'  => $request->get('input-email'),
            'password' => $request->get('input-password')
        );
        
        if(!Auth::attempt($user_data)){
            return redirect('users');
        }
        
        if ( Auth::check() ) {
            return redirect('users/details');
        }
    }
    
    function logout(){
        Auth::logout();
        return redirect('users');
    }

}
<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Notifiable;
    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';
    public $timestamps = false; 
    
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password', 'gf_remember_token',
    ];
    
    /**
     * Get the password for the user.
     *
     * @return string
     */
    public function getAuthPassword(){
        return $this->gf_password;
    }
    
    /**
     * Get the token value for the "remember me" session.
     *
     * @return string
     */
    public function getRememberToken()
    {
        return $this->gf_remember_token;
    }
    
    /**
     * Set the token value for the "remember me" session.
     *
     * @param  string  $value
     * @return void
     */
    public function setRememberToken($value)
    {
        $this->gf_remember_token = $value;
    }
    
    /**
     * Get the column name for the "remember me" token.
     *
     * @return string
     */
    public function getRememberTokenName()
    {
        return 'gf_remember_token';
    }
    
    /**
     * Get the e-mail address where password reminders are sent.
     *
     * @return string
     */
    public function getReminderEmail()
    {
        return $this->gf_email;
    }
}
NewLoginController.php

return [

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

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

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    ],

    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\GFUsers::class
        ],
    ],

    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];
// Authentication Routes
Route::get('users', 'Auth\NewLoginController@showLoginFormUsers')->name('login');
Route::post('users', 'Auth\NewLoginController@checklogin');
Route::post('logout', 'Auth\NewLoginController@logout')->name('logout');
// Registration Routes
Route::get('users/registration', 'Auth\RegisterController@showRegistrationFormUsers')->name('register');
Route::post('users/registration', 'Auth\RegisterController@register');
<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\Request;

class LoginController extends Controller
{

    use AuthenticatesUsers;
    protected $redirectTo = '/users/details';

    public function __construct()
    {
        $this->middleware('guest')->except('logout');
    }
    
    
    public function showLoginFormUsers(){
        return view('users.login');
    }
    
    public function username(){
        return 'gf_email';
    }
    
    function checklogin(Request $request){
        
        $this->validate($request, [
            'input-email' => 'required', 
            'input-password' => 'required',
        ]);
        
        $user_data = array(
            'gf_email'  => $request->get('input-email'),
            'password' => $request->get('input-password')
        );
        
        if(!Auth::attempt($user_data)){
            return redirect('users');
        }
        
        if ( Auth::check() ) {
            return redirect('users/details');
        }
    }
    
    function logout(){
        Auth::logout();
        return redirect('users');
    }

}
<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Notifiable;
    protected $table = 'gf_users';
    protected $primaryKey = 'gf_id';
    public $timestamps = false; 
    
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'gf_email', 'gf_password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'gf_password', 'gf_remember_token',
    ];
    
    /**
     * Get the password for the user.
     *
     * @return string
     */
    public function getAuthPassword(){
        return $this->gf_password;
    }
    
    /**
     * Get the token value for the "remember me" session.
     *
     * @return string
     */
    public function getRememberToken()
    {
        return $this->gf_remember_token;
    }
    
    /**
     * Set the token value for the "remember me" session.
     *
     * @param  string  $value
     * @return void
     */
    public function setRememberToken($value)
    {
        $this->gf_remember_token = $value;
    }
    
    /**
     * Get the column name for the "remember me" token.
     *
     * @return string
     */
    public function getRememberTokenName()
    {
        return 'gf_remember_token';
    }
    
    /**
     * Get the e-mail address where password reminders are sent.
     *
     * @return string
     */
    public function getReminderEmail()
    {
        return $this->gf_email;
    }
}

config/auth.php缺少gf_用户的自定义保护。注册很简单,但身份验证将花费您一些时间每个问题一个问题也许这在代码检查时会更好。为用户创建一个表,为角色管理另一个表,为映射管理另一个表,并创建一个将进行检查的用户的最佳方法用户角色和重定向用户相应的'gfusers'=>['driver'=>'session','provider'=>'gfusers',],@Giu,只需复制默认角色并进行一些修改OK,但我不知道如何在laravel中进行自定义登录。实际上,我不明白为什么需要自定义。默认登录和注册功能是否有效?您可以相对轻松地覆盖默认登录控制器方法。如果默认登录比在路由文件中更有效,则会出现如下情况-Auth::routes();。您可以找到定义这些身份验证路由的位置(vendor/laravel/framework/src/illumb/Routing/Routing/Router.php),而不是这一行,并将它们经典地写入路由文件中。这将允许将URI从/login更改为/public/users。对于LoginController,我是否将该代码放入函数中?例如
public function login(){Auth::guard('gfuser')->login($user);}
Yes。您可以创建一个请求获取用户名和密码的函数。有很多方法可以做到这一点