LoginController.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Models\User;
  4. use Illuminate\Http\Request;
  5. use Response;
  6. use Redirect;
  7. use Captcha;
  8. use Session;
  9. use Cache;
  10. /**
  11. * 登录控制器
  12. * Class LoginController
  13. *
  14. * @package App\Http\Controllers
  15. */
  16. class LoginController extends Controller
  17. {
  18. // 登录页
  19. public function index(Request $request)
  20. {
  21. if ($request->method() == 'POST') {
  22. $username = trim($request->get('username'));
  23. $password = trim($request->get('password'));
  24. $captcha = trim($request->get('captcha'));
  25. if (empty($username) || empty($password)) {
  26. Session::flash('errorMsg', '请输入用户名和密码');
  27. return Redirect::back();
  28. }
  29. // 是否校验验证码
  30. if ($this->systemConfig['is_captcha']) {
  31. if (!Captcha::check($captcha)) {
  32. Session::flash('errorMsg', '验证码错误,请重新输入');
  33. return Redirect::back()->withInput();
  34. }
  35. }
  36. $user = User::query()->where('username', $username)->where('password', md5($password))->first();
  37. if (!$user) {
  38. Session::flash('errorMsg', '用户名或密码错误');
  39. return Redirect::back()->withInput();
  40. } else if (!$user->is_admin && $user->status < 0) {
  41. Session::flash('errorMsg', '账号已禁用');
  42. return Redirect::back();
  43. } else if ($user->status == 0 && $this->systemConfig['is_active_register'] && $user->is_admin == 0) {
  44. Session::flash('errorMsg', '账号未激活,请先<a href="/activeUser?username=' . $user->username . '" target="_blank"><span style="color:#000">【激活账号】</span></a>');
  45. return Redirect::back()->withInput();
  46. }
  47. // 更新登录信息
  48. $remember_token = "";
  49. User::query()->where('id', $user->id)->update(['last_login' => time()]);
  50. if ($request->get('remember')) {
  51. $remember_token = makeRandStr(20);
  52. User::query()->where('id', $user->id)->update(['last_login' => time(), "remember_token" => $remember_token]);
  53. } else {
  54. User::query()->where('id', $user->id)->update(['last_login' => time()]);
  55. }
  56. // 登录送积分
  57. if ($this->systemConfig['login_add_score']) {
  58. if (!Cache::has('loginAddScore_' . md5($username))) {
  59. $score = mt_rand($this->systemConfig['min_rand_score'], $this->systemConfig['max_rand_score']);
  60. $ret = User::query()->where('id', $user->id)->increment('score', $score);
  61. if ($ret) {
  62. $this->addUserScoreLog($user->id, $user->score, $user->score + $score, $score, '登录送积分');
  63. // 登录多久后再登录可以获取积分
  64. $ttl = $this->systemConfig['login_add_score_range'] ? $this->systemConfig['login_add_score_range'] : 1440;
  65. Cache::put('loginAddScore_' . md5($username), '1', $ttl);
  66. Session::flash('successMsg', '欢迎回来,系统自动赠送您 ' . $score . ' 积分,您可以用它兑换流量包');
  67. }
  68. }
  69. }
  70. // 重新取出用户信息
  71. $userInfo = User::query()->where('id', $user->id)->first();
  72. Session::put('user', $userInfo->toArray());
  73. // 根据权限跳转
  74. if ($user->is_admin) {
  75. return Redirect::to('admin')->cookie('remember', $remember_token, 36000);
  76. }
  77. return Redirect::to('/')->cookie('remember', $remember_token, 36000);
  78. } else {
  79. if ($request->cookie("remember")) {
  80. $u = User::query()->where("remember_token", $request->cookie("remember"))->first();
  81. if ($u) {
  82. Session::put('user', $u->toArray());
  83. if ($u->is_admin) {
  84. return Redirect::to('admin');
  85. }
  86. return Redirect::to('/');
  87. }
  88. }
  89. $view['is_captcha'] = $this->systemConfig['is_captcha'];
  90. $view['is_register'] = $this->systemConfig['is_register'];
  91. $view['website_home_logo'] = $this->systemConfig['website_home_logo'];
  92. $view['website_analytics'] = $this->systemConfig['website_analytics'];
  93. $view['website_customer_service'] = $this->systemConfig['website_customer_service'];
  94. return Response::view('login', $view);
  95. }
  96. }
  97. // 退出
  98. public function logout(Request $request)
  99. {
  100. Session::flush();
  101. return Redirect::to('login')->cookie('remember', "", 36000);
  102. }
  103. }