Login.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. namespace app\user\controller;
  3. use think\Controller;
  4. use think\Lang;
  5. use think\Validate;
  6. class Login extends Controller
  7. {
  8. public function _initialize()
  9. {
  10. parent::_initialize();
  11. Lang::load(APP_PATH . 'admin/lang/' . config('default_lang') . '/login.lang.php');
  12. }
  13. /**
  14. * 登录
  15. * @return mixed
  16. */
  17. public function index()
  18. {
  19. if (session('user_id')) {
  20. $this->success('已经登录', 'User/Index/index');
  21. }
  22. if (request()->isPost()) {
  23. $user_email = input('post.user_email');
  24. $user_password = input('post.user_password');
  25. // $captcha = input('post.captcha');
  26. $data = array(
  27. 'user_email' => $user_email,
  28. 'user_password' => $user_password,
  29. // 'captcha' => $captcha,
  30. );
  31. //验证数据 BEGIN
  32. $rule = [
  33. ['user_email', 'require|min:2', '帐号为必填|帐号长度至少为2位'],
  34. ['user_password', 'require|min:2', '密码为必填|帐号长度至少为6位'],
  35. // ['captcha', 'require|min:3', '验证码为必填|帐号长度至少为3位'],
  36. ];
  37. $validate = new Validate($rule);
  38. $validate_result = $validate->check($data);
  39. if (!$validate_result) {
  40. $this->error($validate->getError());
  41. }
  42. //验证数据 END
  43. // if (!captcha_check(input('post.captcha'))) {
  44. // //验证失败
  45. // $this->error('验证码错误');
  46. // }
  47. $condition['user_email'] = $user_email;
  48. $condition['user_password'] = md5($user_password);
  49. $user_info = db('user')->where($condition)->find();
  50. if (is_array($user_info) and !empty($user_info)) {
  51. //更新 admin 最新信息
  52. $update_info = array(
  53. // 'admin_login_num' => ($admin_info['admin_login_num'] + 1),
  54. 'user_loginTime' => TIMESTAMP
  55. );
  56. db('user')->where('user_id', $user_info['user_id'])->update($update_info);
  57. //设置 session
  58. session('user_id', $user_info['user_id']);
  59. session('user_email', $user_info['user_email']);
  60. return $this->redirect('User/Index/index');
  61. } else {
  62. $this->success('帐号密码错误');
  63. }
  64. } else {
  65. return $this->fetch();
  66. }
  67. }
  68. /**
  69. * 退出登录
  70. */
  71. public function logout()
  72. {
  73. //设置 session
  74. session(null);
  75. return $this->redirect('User/Login/index');
  76. exit;
  77. }
  78. }
  79. ?>