仅使用不带密码的电话号码登录-Laravel

时间:2020-02-25 19:36:29

标签: php laravel laravel-5 google-authentication

我在Laravel工作,到目前为止,我使用Guard创建了两个登录名。现在,我正在尝试使用社交名流通过Google登录。因此,从Google成功进行身份验证后,我得到了一个用户个人资料。 因此,我可以让用户收到电子邮件ID。现在,我想使用密码通过同一管理员登录。

'adminpanel' => [
            'driver' => 'session',
            'provider' => 'adminusers',
        ],
         'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    ]
'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],
'adminusers' => [
            'driver' => 'eloquent',
            'model' => App\VendorUser::class,
        ],
    ],

所以有什么技巧可以进行身份​​验证,我尝试了很多。

1 个答案:

答案 0 :(得分:0)

更改app / Http / Middleware / RedirectIfAuthenticated.php的句柄功能

public function handle($request, Closure $next, $guard = null)
{
    if (Auth::check()) {
        return redirect('/home');
    }

    return $next($request);
}

修改并覆盖您的登录功能:

public function login(Request $request)
{
    $this->validate($request, [
        'mobile_no' => 'required|regex:/[0-9]{10}/|digits:10',            
    ]);

    $user = User::where('mobile_no', $request->get('mobile_no'))->first();

    // Check Condition Mobile No. Found or Not
    if($request->get('mobile_no') != $user->mobile_no) {
        \Session::put('errors', 'Your mobile number not match in our system..!!');
        return back();
    }        

    \Auth::login($user);

    return redirect()->route('home');
}

在resources / views / auth / login.blade.php中为mobile_no添加条目

<div class="form-group{{ $errors->has('mobile_no') ? ' has-error' : '' }}">
<label for="mobile_no" class="col-md-4 control-label">Enter Mobile No.</label>
<div class="col-md-6">
     <input id="mobile_no" type="text" class="form-control" name="mobile_no" value="{{ old('mobile_no') }}" required autofocus>
       @if ($errors->has('mobile_no'))
            <span class="help-block">
               <strong>{{ $errors->first('mobile_no') }}</strong>
            </span>
       @endif
</div>
</div>