简体   繁体   中英

Login by Email/Phone number in Laravel Auth()

I am using

Route::auth();

for making user login in Laravel. There are multiple phones linked to a user and saved in table:phones. Tables are users : id,email,password phones: id,user_id,phone_number

How to make user login with both Email/Phones and password

In App\\Traits\\Auth , create a file named LoginUser.php .

<?php

namespace App\Traits\Auth;

use App\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Validator;

trait LoginUser
{

    /**
     * Handle a Authenticates the User.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function login(Request $request)
    {
        $this->validateLogin($request);

        if ($this->attemptLogin($request)) {
            return $this->successfulLogin($request);
        }
        return $this->failedLogin($request);
    }

    /**
     * Validate the user login request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return void
     */
    protected function validateLogin(Request $request)
    {
        $this->validate($request, [
            'username' => 'required',
            'password' => 'required',
        ]);
    }
    /**
     * Attempt to log the user into the application.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return bool
     */
    protected function attemptLogin(Request $request)
    {   
        //Try with email AND username fields
        if (Auth::attempt([
            'phone' => $request['username'],
            'password' => $request['password']
            ],$request->has('remember'))
            || Auth::attempt([
            'email' => $request['username'],
            'password' => $request['password']
            ],$request->has('remember'))){
                return true;
        }
        return false;
    }

    /**
     * This is executed when the user successfully logs in
     * 
     * @var Request $request
     * @return Reponse
     */
    protected function successfulLogin(Request $request){
        return redirect($this->redirectTo);
    }

    /**
     * This is executed when the user fails to log in
     * 
     * @var Request $request
     * @return Reponse
     */
    protected function failedLogin(Request $request){
        return redirect()->back()->withErrors(['password' => 'You entered the wrong username or password']);
    }

}

Then in

App\\Http\\Controllers\\Auth

rewrite (or create) LoginController.php and paste this

<?php

namespace App\Http\Controllers\Auth;

use App\Traits\Auth\LoginUser;
use App\Http\Controllers\Controller;

class LoginController extends Controller
{
    use LoginUser;

    /**
     * Where to redirect users after registration.
     *
     * @var string | URL
     */
    protected $redirectTo = '/mPanel';

    /**
     * Displays login page
     * 
     * @return \Illuminate\Http\Response
     */
    public function show(){
        return response()->view('LOGIN PAGE HERE');
    }

}

Finally in your routes file, add these routes:

Route::get('login', 'Auth\LoginController@show');
Route::post('login', 'Auth\LoginController@login');

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM