AuthController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\User\ForgetPasswordEmialRequest;
  5. use App\Http\Requests\API\User\LoginRequest;
  6. use App\Http\Requests\API\User\ResetPasswordRequest;
  7. use App\Mail\ForgetPasswordMailable;
  8. use App\Models\User;
  9. use Carbon\Carbon;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Support\Facades\Auth;
  12. use Illuminate\Support\Facades\Cache;
  13. use Illuminate\Support\Facades\DB;
  14. use Illuminate\Support\Facades\Hash;
  15. use Illuminate\Support\Facades\Mail;
  16. use Illuminate\Support\Str;
  17. use Illuminate\Validation\ValidationException;
  18. class AuthController extends Controller
  19. {
  20. public function login(LoginRequest $request)
  21. {
  22. $user = User::query()
  23. ->where("username", $request->username)
  24. ->orWhere("email", $request->username)
  25. ->first();
  26. if (! $user || ! Hash::check($request->password, $user->password)) {
  27. throw ValidationException::withMessages([
  28. 'username' => [__("auth.failed")],
  29. ]);
  30. }
  31. if ($user->status===0){
  32. throw ValidationException::withMessages([
  33. 'username' => [__("auth.ban")],
  34. ]);
  35. }
  36. // 创建token
  37. $token = $user->createToken('user')->plainTextToken;
  38. //用户信息放入缓存
  39. $cacheKey = 'auth_token'.$token;
  40. Cache::put($cacheKey, [
  41. 'user_id' => $user->id,
  42. 'username' => $user->username,
  43. 'email' => $user->email,
  44. 'phone' => $user->phone,
  45. 'token' => $token,
  46. ], now()->addHours(2));
  47. return $this->success([
  48. 'data' => [
  49. 'token' => $token,
  50. ]
  51. ]);
  52. }
  53. public function logout(Request $request)
  54. {
  55. //删除缓存token
  56. Auth::user()->currentAccessToken()->delete();
  57. $token = $request->headers->get('Authorization');
  58. // 去除Bearer前缀(如果有的话)
  59. $token = Str::startsWith($token, 'Bearer ') ? Str::substr($token, 7) : $token;
  60. Cache::delete('auth_token' . $token);
  61. return $this->noContent();
  62. }
  63. /**
  64. * 发送重置密码邮件
  65. * @param ForgetPasswordEmialRequest $request username用户名或邮箱
  66. * @return \Illuminate\Http\Response
  67. * @throws \Random\RandomException
  68. */
  69. public function sendForgetPasswordEmail(ForgetPasswordEmialRequest $request)
  70. {
  71. //1.通过用户名或邮箱检索用户
  72. $user = User::query()
  73. ->where('username',$request->username)
  74. ->orWhere('email',$request->username)
  75. ->first();
  76. $code = uniqid();
  77. $exists = DB::table('password_reset_tokens')->where('email', $user->email)->exists();
  78. if ($exists) {
  79. // 如果记录存在,更新它
  80. DB::table('password_reset_tokens')->where('email', $user->email)->update([
  81. 'token' => $code,
  82. 'exp_date' => Carbon::now(),
  83. ]);
  84. } else {
  85. // 如果记录不存在,插入新记录
  86. DB::table('password_reset_tokens')->insert([
  87. 'email' => $user->email,
  88. 'token' => $code,
  89. 'created_at' => Carbon::now(),
  90. 'exp_date' => Carbon::now(),
  91. ]);
  92. }
  93. //3.发送重置验证码邮件
  94. Mail::to($user)->send(new ForgetPasswordMailable($code));
  95. return $this->noContent();
  96. }
  97. /**
  98. * 重置用户密码
  99. * @param ResetPasswordRequest $request
  100. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Response
  101. */
  102. public function resetPassword(ResetPasswordRequest $request)
  103. {
  104. //1.通过用户名或邮箱检索用户
  105. $user = User::query()
  106. ->where('username',$request->username)
  107. ->orWhere('email',$request->username)
  108. ->first();
  109. //2.获取该用户的最后验证码信息
  110. $resetToken = DB::table('password_reset_tokens')
  111. ->where('email', $user->email)
  112. ->orderBy('created_at', 'desc')
  113. ->first(); // 获取第一条记录;
  114. //3.判断验证码是否存在 验证码是否一致 验证码是否过期(15分钟) 若过期,执行以下if代码
  115. if (!$resetToken || $resetToken->token != $request->code || Carbon::parse($resetToken->exp_date)->diffInMinutes(Carbon::now()) > 15){
  116. return $this->badRequest('Verification code error or expired');
  117. }
  118. //4.一切没问题,则修改该用户的密码
  119. $user->password = Hash::make($request->new_password);
  120. $user->save();
  121. return $this->noContent();
  122. }
  123. }