LoginController.php 5.2 KB

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