侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

基于Laravel5.4实现多字段登录功能方法示例

Laravel  /  管理员 发布于 9年前   617

前言

最近在一个项目中需要实现一个多字段登录功能,简单来说就是可以使用用户名、邮箱或手机号任意一种方式进行登录。所以本文就来给大家介绍了关于Laravel5.4多字段登录的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧。

以下内容基于laravel5.4

方法如下:

首先,通过artisan工具生成auth模块

php artisan make:auth

这时候App\Http\Controllers目录下会新增一个Auth目录,该目录下为注册登录相关的控制器,resources\views目录下也会生成一些与注册登录相关的视图

laravel的官方文档中说手动认证用户需要使用Illuminate\Support\Facades\Auth类的attempt方法,如下:

 $email, 'password' => $password])) {   // Authentication passed...   return redirect()->intended('dashboard');  } }}

这个方法会根据你传入的参数判断数据库中是否存在与之相匹配的用户,如果存在并且密码正确返回true,反之返回false

遂在LoginController中添加该方法,但是好像并没有效果

于是开始观察LoginController的实现机制,发现它实现了一个AuthenticatesUsers的trait,追踪到这个trait的定义文件,发现这个文件就是我们想要的东西

里面有一个login方法,就是负责处理登录的逻辑

/**  * Handle a login request to the application.  *  * @param \Illuminate\Http\Request $request  * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\Response  */ public function login(Request $request) {  // 表单验证  $this->validateLogin($request);  // If the class is using the ThrottlesLogins trait, we can automatically throttle  // the login attempts for this application. We'll key this by the username and  // the IP address of the client making these requests into this application.  // 防止暴力破解,多次登录失败会根据IP锁定  if ($this->hasTooManyLoginAttempts($request)) {   $this->fireLockoutEvent($request);   return $this->sendLockoutResponse($request);  }    // 这个就是主要的负责判断数据库中是否存在相应的账号和密码的地方,我们需要重写的就是attemptLogin方法  if ($this->attemptLogin($request)) {   return $this->sendLoginResponse($request);  }  // If the login attempt was unsuccessful we will increment the number of attempts  // to login and redirect the user back to the login form. Of course, when this  // user surpasses their maximum number of attempts they will get locked out.  // 登录失败,失败次数++,防止暴力破解  $this->incrementLoginAttempts($request);  // 返回失败响应  return $this->sendFailedLoginResponse($request); }

分析了一波这个文件,发现主要进行登录判断的就是attemptLogin方法,我们只要重写这个方法即可,先看看原来的是怎么写的,根据原来的进行重写:

/**  * Attempt to log the user into the application.  *  * @param \Illuminate\Http\Request $request  * @return bool  */ protected function attemptLogin(Request $request) {  return $this->guard()->attempt(   $this->credentials($request), $request->has('remember')  ); }

在LoginController重写后:

public function attemptLogin(Request $request) {  $username = $request->input('username');  $password = $request->input('password');  // 验证用户名登录方式  $usernameLogin = $this->guard()->attempt(   ['username' => $username, 'password' => $password], $request->has('remember')  );  if ($usernameLogin) {   return true;  }  // 验证手机号登录方式  $mobileLogin = $this->guard()->attempt(   ['mobile' => $username, 'password' => $password], $request->has('remember')  );  if ($mobileLogin) {   return true;  }  // 验证邮箱登录方式  $emailLogin = $this->guard()->attempt(   ['email' => $username, 'password' => $password], $request->has('remember')  );  if ($emailLogin) {   return true;  }  return false; }

只需要用attempt方法进行多次判断即可,只要成功就返回true,不成功继续用其他字段进行判断,都不成功则返回flase

测试,可以实现多字段登录效果

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家的支持。

您可能感兴趣的文章:

  • Laravel 5.4重新登录实现跳转到登录前页面的原理和方法
  • Laravel5.2使用Captcha生成验证码实现登录(session巨坑)
  • laravel5.2实现区分前后台用户登录的方法
  • laravel5实现微信第三方登录功能
  • Laravel5.5 实现后台管理登录的方法(自定义用户表登录)
  • 解决laravel5中auth用户登录其他页面获取不到登录信息的问题
  • laravel 5.3 单用户登录简单实现方法
  • Laravel5.4框架使用socialite实现github登录的方法
  • Laravel 5.5 实现禁用用户注册示例
  • Laravel5.1 框架登录和注册实现方法详解


  • 上一条:
    如何修改Laravel中url()函数生成URL的根地址
    下一条:
    如何利用预加载优化Laravel Model查询详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
    • Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
    • Laravel的轻量型购物车扩展包:binafy/laravel-cart(37个评论)
    • Laravel 11.11版本发布 - 查看模型中的第三方关系:show(0个评论)
    • 近期文章
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客