基于Laravel5.4实现多字段登录功能方法示例
前言
最近在一个项目中需要实现一个多字段登录功能,简单来说就是可以使用用户名、邮箱或手机号任意一种方式进行登录。所以本文就来给大家介绍了关于Laravel5.4多字段登录的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧。
以下内容基于laravel5.4
方法如下:
首先,通过artisan工具生成auth模块
phpartisanmake:auth
这时候App\Http\Controllers目录下会新增一个Auth目录,该目录下为注册登录相关的控制器,resources\views目录下也会生成一些与注册登录相关的视图
laravel的官方文档中说手动认证用户需要使用Illuminate\Support\Facades\Auth类的attempt方法,如下:
$email,'password'=>$password])){ //Authenticationpassed... returnredirect()->intended('dashboard'); } } }
这个方法会根据你传入的参数判断数据库中是否存在与之相匹配的用户,如果存在并且密码正确返回true,反之返回false
遂在LoginController中添加该方法,但是好像并没有效果
于是开始观察LoginController的实现机制,发现它实现了一个AuthenticatesUsers的trait,追踪到这个trait的定义文件,发现这个文件就是我们想要的东西
里面有一个login方法,就是负责处理登录的逻辑
/** *Handlealoginrequesttotheapplication. * *@param\Illuminate\Http\Request$request *@return\Illuminate\Http\RedirectResponse|\Illuminate\Http\Response */ publicfunctionlogin(Request$request) { //表单验证 $this->validateLogin($request); //IftheclassisusingtheThrottlesLoginstrait,wecanautomaticallythrottle //theloginattemptsforthisapplication.We'llkeythisbytheusernameand //theIPaddressoftheclientmakingtheserequestsintothisapplication. //防止暴力破解,多次登录失败会根据IP锁定 if($this->hasTooManyLoginAttempts($request)){ $this->fireLockoutEvent($request); return$this->sendLockoutResponse($request); } //这个就是主要的负责判断数据库中是否存在相应的账号和密码的地方,我们需要重写的就是attemptLogin方法 if($this->attemptLogin($request)){ return$this->sendLoginResponse($request); } //Iftheloginattemptwasunsuccessfulwewillincrementthenumberofattempts //tologinandredirecttheuserbacktotheloginform.Ofcourse,whenthis //usersurpassestheirmaximumnumberofattemptstheywillgetlockedout. //登录失败,失败次数++,防止暴力破解 $this->incrementLoginAttempts($request); //返回失败响应 return$this->sendFailedLoginResponse($request); }
分析了一波这个文件,发现主要进行登录判断的就是attemptLogin方法,我们只要重写这个方法即可,先看看原来的是怎么写的,根据原来的进行重写:
/** *Attempttologtheuserintotheapplication. * *@param\Illuminate\Http\Request$request *@returnbool */ protectedfunctionattemptLogin(Request$request) { return$this->guard()->attempt( $this->credentials($request),$request->has('remember') ); }
在LoginController重写后:
publicfunctionattemptLogin(Request$request) { $username=$request->input('username'); $password=$request->input('password'); //验证用户名登录方式 $usernameLogin=$this->guard()->attempt( ['username'=>$username,'password'=>$password],$request->has('remember') ); if($usernameLogin){ returntrue; } //验证手机号登录方式 $mobileLogin=$this->guard()->attempt( ['mobile'=>$username,'password'=>$password],$request->has('remember') ); if($mobileLogin){ returntrue; } //验证邮箱登录方式 $emailLogin=$this->guard()->attempt( ['email'=>$username,'password'=>$password],$request->has('remember') ); if($emailLogin){ returntrue; } returnfalse; }
只需要用attempt方法进行多次判断即可,只要成功就返回true,不成功继续用其他字段进行判断,都不成功则返回flase
测试,可以实现多字段登录效果
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。