LoginController.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace App\Module\OAuth\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Module\OAuth\Services\AuthService;
  5. use Illuminate\Http\Request;
  6. class LoginController extends Controller
  7. {
  8. protected $auth;
  9. public function __construct(AuthService $auth)
  10. {
  11. $this->auth = $auth;
  12. }
  13. /**
  14. * 显示登录页面
  15. */
  16. public function showLoginForm(Request $request)
  17. {
  18. $data = $request->session()->all();
  19. dump($data);
  20. // 如果已经登录,检查是否有待处理的授权请求
  21. if ($this->auth->check()) {
  22. if ($authorizeParams = session('oauth_authorize_params')) {
  23. session()->forget('oauth_authorize_params');
  24. return redirect()->route('oauth.authorize', $authorizeParams);
  25. }
  26. return redirect('/');
  27. }
  28. return view('oauth::login');
  29. }
  30. /**
  31. * 处理登录请求
  32. */
  33. public function login(Request $request)
  34. {
  35. $credentials = $request->validate([
  36. 'username' => 'required|string',
  37. 'password' => 'required|string',
  38. ]);
  39. if ($user = $this->auth->attempt($credentials['username'], $credentials['password'])) {
  40. // 检查是否有待处理的授权请求
  41. if ($authorizeParams = session('oauth_authorize_params')) {
  42. session()->forget('oauth_authorize_params');
  43. return redirect()->route('oauth.authorize', $authorizeParams);
  44. }
  45. return redirect('/');
  46. }
  47. return back()->withErrors([
  48. 'username' => '用户名或密码错误',
  49. ])->withInput();
  50. }
  51. /**
  52. * 退出登录
  53. */
  54. public function logout(Request $request)
  55. {
  56. $this->auth->logout();
  57. return redirect()->route('login');
  58. }
  59. }