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框架邮箱认证实现方法详解