Laravel重写用户登录简单示例

本文实例讲述了Laravel重写用户登录的方法。分享给大家供大家参考,具体如下:

class AuthController extends Controller

{

//

use ThrottlesLogins, AuthenticatesAndRegistersUsers;

protected $redirectTo = 'admin/index';

protected $loginView = 'admin/login';

protected $guard = 'admin';

protected $redirectAfterLogout = 'admin/login';

protected $maxLoginAttempts = 5; //每分钟最大尝试登录次数

protected $lockoutTime = 600; //登录锁定时间

function __construct()

{

$this->middleware('guest:admin', ['except' => 'logout']);

}

protected function validator(array $data)

{

return Validator::make($data, [

'username' => 'required|max:255',

'email' => 'required|email|max:255|unique:admin_users',

'password' => 'required|confirmed|min:6',

]);

}

/**

* @param Request $request

*/

protected function validateLogin(Request $request)

{

$this->validate($request,[

$this->loginUsername() => 'required',

'password' => 'required',

'captcha' => 'required|captcha'

], [

'email.required' => '邮箱必须',

'password.required' => '密码必须',

'captcha.captcha' => '验证码错误',

'captcha.required' => '验证码必须',

]);

}

/**

* 重写登录

* @param 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.

$throttles = $this->isUsingThrottlesLoginsTrait();

//dd($this->hasTooManyLoginAttempts($request));

if ($throttles && $lockedOut = $this->hasTooManyLoginAttempts($request)) {

$this->fireLockoutEvent($request);

//日志记录

$this->login_logs(['email'=>$request->input('email'), 'login_ip'=>$request->ip(), 'login_result'=>0, 'comments'=>'限制登录10分钟']);

return $this->sendLockoutResponse($request);

}

$credentials = $this->getCredentials($request);

if (Auth::guard($this->getGuard())->attempt($credentials, $request->has('remember'))) {

//日志记录

$this->login_logs(['email'=>$request->input('email'), 'login_ip'=>$request->ip(), 'login_result'=>1, 'comments'=>'登录成功']);

return $this->handleUserWasAuthenticated($request, $throttles);

}

// 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.

if ($throttles && ! $lockedOut) {

//日志记录

$this->login_logs(['email'=>$request->input('email'), 'login_ip'=>$request->ip(), 'login_result'=>0, 'comments'=>'登录失败']);

$this->incrementLoginAttempts($request);

}

return $this->sendFailedLoginResponse($request);

}

/**

* 登录记录

* @param $data

*/

private function login_logs ($data)

{

LoginLog::create($data);

}

}

直接重写login方法,其实我是复制了原方法然后加入了一些自己的东西。

主要的一些修改就是:

1. 加入验证码(自定义了验证信息及提示)。

2. 后台登录频率的限制。

3. 登录日志记录。

更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php日期与时间用法总结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

以上是 Laravel重写用户登录简单示例 的全部内容, 来源链接: utcz.com/z/325298.html

回到顶部