LoginController.php 4.0 KB

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