Laravel中默认的登录是通过邮箱和密码进行登录的。那么,怎么样才能用最少的改动将它改成用密码登录呢?
默认的,Laravel使用的是 Illuminate\Foundation\Auth\AuthenticatesUsers
这个trait完成登录功能的。通过观察 AuthenticatesUsers
的代码,发现下面一段很有意思的代码:
protected function validateLogin(Request $request) { $this->validate($request, [ $this->username() => 'required|string', 'password' => 'required|string', ]); } public function username() { return 'email'; }
可以看到,是 因 为trait里定义了用户名就是email,所以才会使得验证的时候通过用户邮箱验证。 所以我们只需要定义一个trait,覆盖 AuthenticatesUsers
中的 username()
方法即可实现后端代码通过用户名验证登录。
新增的trait代码
namespace App\Utils;
use Illuminate\Foundation\Auth\AuthenticatesUsers as LaravelAuthenticatesUsers; trait AuthenticatesUsers { use LaravelAuthenticatesUsers; public function username() { return 'name'; } }
其实还有另一个简单的修改方式,直接在LoginController
中新增 username()
方法。由于当前定义方法会覆盖trait的方法,因此也能达到修改的目的。但是会破坏登录代码的整体一致性,所以最好还是通过新增trait的方式实现。
同时要记得修改前端blade文件中对输入参数的验证,然后就可以使用用户名登录了
总结
以上所述是小编给大家介绍的Laravel 默认邮箱登录改成用户名登录的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对华域联盟网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣的文章:
- laravel5.4利用163邮箱发送邮件的步骤详解
- 在Laravel框架里实现发送邮件实例(邮箱验证)
- Laravel 5框架学习之用户认证
- 详解Laravel5.6 Passport实现Api接口认证
- Laravel5.5中利用Passport实现Auth认证的方法
- Laravel实现用户多字段认证的解决方法
- Laravel认证原理以及完全自定义认证详解
- Laravel多用户认证系统示例详解
- 解决Laravel5.2 Auth认证退出失效的问题
- laravel实现Auth认证,登录、注册后的页面回跳方法
- laravel框架邮箱认证实现方法详解
本文由 华域联盟 原创撰写:华域联盟 » Laravel 默认邮箱登录改成用户名登录的实现方法
转载请保留出处和原文链接:https://www.cnhackhy.com/61517.htm