LoginController.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Components\Helpers;
  4. use App\Components\QQWry;
  5. use App\Http\Models\User;
  6. use App\Http\Models\UserLoginLog;
  7. use Illuminate\Http\Request;
  8. use Response;
  9. use Redirect;
  10. use Captcha;
  11. use Session;
  12. use Cache;
  13. use Log;
  14. use Auth;
  15. /**
  16. * 登录控制器
  17. * Class LoginController
  18. *
  19. * @package App\Http\Controllers
  20. */
  21. class LoginController extends Controller
  22. {
  23. protected static $systemConfig;
  24. function __construct()
  25. {
  26. self::$systemConfig = Helpers::systemConfig();
  27. }
  28. // 登录页
  29. public function index(Request $request)
  30. {
  31. if ($request->method() == 'POST') {
  32. $username = trim($request->get('username'));
  33. $password = trim($request->get('password'));
  34. $captcha = trim($request->get('captcha'));
  35. $remember = trim($request->get('remember'));
  36. if (empty($username) || empty($password)) {
  37. Session::flash('errorMsg', '请输入用户名和密码');
  38. return Redirect::back();
  39. }
  40. // 是否校验验证码
  41. if (self::$systemConfig['is_captcha']) {
  42. if (!Captcha::check($captcha)) {
  43. Session::flash('errorMsg', '验证码错误,请重新输入');
  44. return Redirect::back()->withInput();
  45. }
  46. }
  47. if (!Auth::attempt(['username' => $username, 'password' => $password], $remember)) {
  48. Session::flash('errorMsg', '用户名或密码错误');
  49. return Redirect::back()->withInput();
  50. } elseif (!Auth::user()->is_admin && Auth::user()->status < 0) {
  51. Session::flash('errorMsg', '账号已禁用');
  52. return Redirect::back();
  53. } elseif (Auth::user()->status == 0 && self::$systemConfig['is_active_register'] && Auth::user()->is_admin == 0) {
  54. Session::flash('errorMsg', '账号未激活,请点击<a href="/activeUser?username=' . Auth::user()->username . '" target="_blank"><span style="color:#000">【激活账号】</span></a>');
  55. return Redirect::back()->withInput();
  56. }
  57. // 登录送积分
  58. if (self::$systemConfig['login_add_score']) {
  59. if (!Cache::has('loginAddScore_' . md5($username))) {
  60. $score = mt_rand(self::$systemConfig['min_rand_score'], self::$systemConfig['max_rand_score']);
  61. $ret = User::query()->where('id', Auth::user()->id)->increment('score', $score);
  62. if ($ret) {
  63. $this->addUserScoreLog(Auth::user()->id, Auth::user()->score, Auth::user()->score + $score, $score, '登录送积分');
  64. // 登录多久后再登录可以获取积分
  65. $ttl = self::$systemConfig['login_add_score_range'] ? self::$systemConfig['login_add_score_range'] : 1440;
  66. Cache::put('loginAddScore_' . md5($username), '1', $ttl);
  67. Session::flash('successMsg', '欢迎回来,系统自动赠送您 ' . $score . ' 积分,您可以用它兑换流量');
  68. }
  69. }
  70. }
  71. // 写入登录日志
  72. $this->addUserLoginLog(Auth::user()->id, getClientIp());
  73. // 更新登录信息
  74. User::query()->where('id', Auth::user()->id)->update(['last_login' => time()]);
  75. // 根据权限跳转
  76. if (Auth::user()->is_admin) {
  77. return Redirect::to('admin');
  78. }
  79. return Redirect::to('/');
  80. } else {
  81. if (Auth::viaRemember()) {
  82. if (Auth::check()) {
  83. if (Auth::user()->is_admin) {
  84. return Redirect::to('admin');
  85. }
  86. return Redirect::to('/');
  87. }
  88. }
  89. $view['is_captcha'] = self::$systemConfig['is_captcha'];
  90. $view['is_register'] = self::$systemConfig['is_register'];
  91. $view['website_home_logo'] = self::$systemConfig['website_home_logo'];
  92. $view['website_analytics'] = self::$systemConfig['website_analytics'];
  93. $view['website_customer_service'] = self::$systemConfig['website_customer_service'];
  94. return Response::view('login', $view);
  95. }
  96. }
  97. // 退出
  98. public function logout(Request $request)
  99. {
  100. Auth::logout();
  101. return Redirect::to('login');
  102. }
  103. // 添加用户登录日志
  104. private function addUserLoginLog($userId, $ip)
  105. {
  106. // 解析IP信息
  107. $qqwry = new QQWry();
  108. $ipInfo = $qqwry->ip($ip);
  109. if (isset($ipInfo['error'])) {
  110. Log::info('无法识别IP,可能是IPv6,尝试解析:' . $ip);
  111. $ipInfo = getIPv6($ip);
  112. }
  113. if (empty($ipInfo) || empty($ipInfo['country'])) {
  114. \Log::warning("获取IP地址信息异常:" . $ip);
  115. }
  116. $log = new UserLoginLog();
  117. $log->user_id = $userId;
  118. $log->ip = $ip;
  119. $log->country = $ipInfo['country'] ?? '';
  120. $log->province = $ipInfo['province'] ?? '';
  121. $log->city = $ipInfo['city'] ?? '';
  122. $log->county = $ipInfo['county'] ?? '';
  123. $log->isp = $ipInfo['isp'] ?? ($ipInfo['organization'] ?? '');
  124. $log->area = $ipInfo['area'] ?? '';
  125. $log->save();
  126. }
  127. }