Register.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. /**
  3. * User: nickbai
  4. * Date: 2017/10/24 10:46
  5. * Email: 1902822973@qq.com
  6. */
  7. namespace app\index\controller;
  8. use think\Db;
  9. use app\index\controller\Common;
  10. class Register extends Common
  11. {
  12. // 注册首页
  13. public function index()
  14. {
  15. $this->assign([
  16. 'version' => config('version')
  17. ]);
  18. return $this->fetch();
  19. }
  20. // 处理注册
  21. public function doRegister()
  22. {
  23. if (request()->isPost()) {
  24. $userName = input("param.user_name/s");
  25. $userEmail = input("param.user_email/s");
  26. $password = input("param.password/s");
  27. $phone = input("param.phone/s");
  28. $emailCode = input("param.code/s");
  29. if (empty($userName)) {
  30. return json(['code' => -1, 'data' => '', 'msg' => '用户名不能为空']);
  31. }
  32. if (empty($userEmail)) {
  33. return json(['code' => -2, 'data' => '', 'msg' => '邮箱不能为空']);
  34. }
  35. if (empty($password)) {
  36. return json(['code' => -3, 'data' => '', 'msg' => '密码不能为空']);
  37. }
  38. if (empty($phone)) {
  39. return json(['code' => -4, 'data' => '', 'msg' => '密码不能为空']);
  40. }
  41. if (empty($emailCode)) {
  42. return json(['code' => -5, 'data' => '', 'msg' => '验证码不能为空']);
  43. }
  44. if ($emailCode != session('code')) {
  45. return json(['code' => -6, 'data' => '', 'msg' => '验证码不正确']);
  46. }
  47. $name = db('accounts')->where('account_name', $userName)->find();
  48. if (!empty($name)) {
  49. return json(['code' => -7, 'data' => '', 'msg' => '用户名已存在']);
  50. }
  51. $email = db('accounts')->where('account_email', $userEmail)->find();
  52. if (!empty($email)) {
  53. return json(['code' => -8, 'data' => '', 'msg' => '邮箱已存在']);
  54. }
  55. // 添加用户信息
  56. $userInfo = [
  57. 'account_name' => $userName,
  58. 'account_email' => $userEmail,
  59. 'password' => md5($password . config('salt')),
  60. 'account_phone' => $phone,
  61. 'status' => 1,
  62. 'add_time' => time(),
  63. 'last_login_time' => time()
  64. ];
  65. $user_id = db('accounts')->insertGetId($userInfo);
  66. // 注册成功 生成token
  67. $module = mt_rand(100000, 999999);
  68. $token = base64_encode($module . '#$@%!^*/' . time() . '/' . $userInfo['id']);
  69. // 更新用户状态
  70. $param = [
  71. 'token' => $token,
  72. 'expire_time' => time(),
  73. ];
  74. db('accounts')->where('id', $user_id)->update($param);
  75. return json(['code' => 1, 'data' => url('user/index'), 'msg' => '注册成功']);
  76. }
  77. }
  78. //自动注册
  79. public function autoReg()
  80. {
  81. if (!$this->verifyApiToken()) {
  82. // return json(['code' => -6, 'data' => [], 'msg' => 'require false']);
  83. }
  84. $appid = input("post.appid/s");
  85. $appuid = input("post.appuid/s");
  86. $token = trim(input("post.token/s"));
  87. $nowuid = (empty($appuid) || empty($appuid)) ? uniqid('anon_') : $appid . '_' . $appuid;
  88. $avatar = "http://wx2.sinaimg.cn/mw690/5db11ff4gy1flxmew7edlj203d03wt8n.jpg"; //默认头像
  89. if ($token) {
  90. $old = db('accounts')->where(['token' => $token])->find();
  91. if ($old) {
  92. if ($old['status'] != 1) {
  93. return json(['code' => 0, 'data' => [], 'msg' => '禁止登陆']);
  94. }
  95. db('accounts')->where(['token' => $token])->update(['last_login_time' => time()]);
  96. return json(['code' => 1, 'data' => ['id' => $old['id'], 'name' => $old['account_name'], 'token' => $old['token'], 'avatar' => $avatar], 'msg' => '注册成功']);
  97. }
  98. }
  99. $old = Db::name('accounts')->where(['account_name' => $nowuid])->find();
  100. if ($old) {
  101. return json(['code' => 1, 'data' => ['id' => $old['id'], 'name' => $nowuid, 'token' => $old['token'], 'avatar' => $avatar], 'msg' => '注册成功']);
  102. }
  103. $now = time();
  104. $token = md5(uniqid() . rand(10000, 50000));
  105. $newdata = [
  106. 'account_name' => $nowuid,
  107. 'password' => md5(time() . rand(1, 5000)),
  108. 'status' => 1,
  109. 'add_time' => $now,
  110. 'last_login_time' => $now,
  111. 'token' => $token,
  112. 'expire_time' => $now,
  113. ];
  114. $retid = Db::name('accounts')->insertGetId($newdata);
  115. if ($retid) {
  116. return json(['code' => 1, 'data' => ['id' => $retid, 'name' => $nowuid, 'token' => $token, 'avatar' => $avatar], 'msg' => '注册成功']);
  117. } else {
  118. return json(['code' => 0, 'data' => [], 'msg' => '注册用户失败']);
  119. }
  120. }
  121. }