laravel5.5 ajax,jquery - Laravel 5.3 Ajax Login - Stack Overflow

The Complete Solution:

Hi reinierkors,

I also tried to do the same with the 5.3 version, I finally solved it :) and the solution is very clean.

First, I created a new folder under App\Http\Controllers\Api called Auth, I did it just to add new auth controllers for the api so I can rewrite some functions, then I copied the auth controllers (LoginController, ForgotPasswordController, RegisterController) to this new folder.

In LoginController Class:

I rewrited the functions that were making the redirects.

The first function: will be automatically called when the

authentication return success.

The second function: will be automatically called when the

authentication return error.

The last function: will be automatically called when the user has been

locked out after trying 5 login attempts.

/**

* Send the response after the user was authenticated.

*

* @param \Illuminate\Http\Request $request

* @return \Illuminate\Http\Response

*/

protected function sendLoginResponse(Request $request) {

$this->clearLoginAttempts($request);

return response()->json(['SUCCESS' => 'AUTHENTICATED'], 200);

}

/**

* Get the failed login response instance.

*

* @return \Illuminate\Http\Response

*/

protected function sendFailedLoginResponse() {

return response()->json(['ERROR' => 'AUTH_FAILED'], 401);

}

/**

* Error after determining they are locked out.

*

* @param \Illuminate\Http\Request $request

* @return \Illuminate\Http\Response

*/

protected function sendLockoutResponse(Request $request) {

$seconds = $this->limiter()->availableIn(

$this->throttleKey($request)

);

return response()->json(['ERROR' => 'TOO_MANY_ATTEMPTS', 'WAIT' => $seconds], 401);

}

In RegisterController Class:

I rewrited the functions that were making the redirects.

In the first function: I modified the validator response to return a more comfortable response (array) to work with.

The second function: will be automatically called when the registration return success.

/**

* Handle a registration request for the application.

*

* @param Request $request

* @return \Illuminate\Http\Response

*/

public function register(Request $request) {

$validator = $this->validator($request->all());

if($validator->fails())

return response()->json(['ERROR' => $validator->errors()->getMessages()], 422);

event(new Registered($user = $this->create($request->all())));

$this->guard()->login($user);

return $this->registered($request, $user)

?: redirect($this->redirectPath());

}

/**

* The user has been registered.

*

* @param Request $request

* @param mixed $user

* @return mixed

*/

protected function registered(Request $request, $user) {

return response()->json(['SUCCESS' => 'AUTHENTICATED']);

}

In ForgotPasswordController Class:

I rewrited the function that was making the redirects.

I modified the reset link email function so we can get the messages and display as json instead of the redirects.

/**

* Send a reset link to the given user.

*

* @param \Illuminate\Http\Request $request

* @return \Illuminate\Http\RedirectResponse

*/

public function sendResetLinkEmail(Request $request)

{

$validator = Validator::make($request->only('email'), [

'email' => 'required|email',

]);

if ($validator->fails())

return response()->json(['ERROR' => 'VALID_EMAIL_REQUIRED'], 422);

// We will send the password reset link to this user. Once we have attempted

// to send the link, we will examine the response then see the message we

// need to show to the user. Finally, we'll send out a proper response.

$response = $this->broker()->sendResetLink(

$request->only('email')

);

if ($response === Password::RESET_LINK_SENT) {

return response()->json(['SUCCESS' => 'EMAIL_SENT'], 200);

}

// If an error was returned by the password broker, we will get this message

// translated so we can notify a user of the problem. We'll redirect back

// to where the users came from so they can attempt this process again.

return response()->json(['ERROR' => 'EMAIL_NOT_FOUND'], 401);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值