Register.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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\Controller;
  9. class Register extends Controller
  10. {
  11. // 注册首页
  12. public function index()
  13. {
  14. $this->assign([
  15. 'version' => config('version')
  16. ]);
  17. return $this->fetch();
  18. }
  19. // 处理注册
  20. public function doRegister()
  21. {
  22. if(request()->isPost()){
  23. $userName = input("param.user_name/s");
  24. $userEmail = input("param.user_email/s");
  25. $password = input("param.password/s");
  26. $phone = input("param.phone/s");
  27. $emailCode = input("param.code/s");
  28. if(empty($userName)){
  29. return json(['code' => -1, 'data' => '', 'msg' => '用户名不能为空']);
  30. }
  31. if(empty($userEmail)){
  32. return json(['code' => -2, 'data' => '', 'msg' => '邮箱不能为空']);
  33. }
  34. if(empty($password)){
  35. return json(['code' => -3, 'data' => '', 'msg' => '密码不能为空']);
  36. }
  37. if(empty($phone)){
  38. return json(['code' => -4, 'data' => '', 'msg' => '密码不能为空']);
  39. }
  40. if(empty($emailCode)){
  41. return json(['code' => -5, 'data' => '', 'msg' => '验证码不能为空']);
  42. }
  43. if($emailCode != session('code')){
  44. return json(['code' => -6, 'data' => '', 'msg' => '验证码不正确']);
  45. }
  46. $name = db('accounts')->where('account_name', $userName)->find();
  47. if(!empty($name)){
  48. return json(['code' => -7, 'data' => '', 'msg' => '用户名已存在']);
  49. }
  50. $email = db('accounts')->where('account_email', $userEmail)->find();
  51. if(!empty($email)){
  52. return json(['code' => -8, 'data' => '', 'msg' => '邮箱已存在']);
  53. }
  54. // 添加用户信息
  55. $userInfo = [
  56. 'account_name' => $userName,
  57. 'account_email' => $userEmail,
  58. 'password' => md5($password . config('salt')),
  59. 'account_phone' => $phone,
  60. 'status' => 1,
  61. 'add_time' => time(),
  62. 'last_login_time' => time()
  63. ];
  64. $user_id = db('accounts')->insertGetId($userInfo);
  65. // 注册成功 生成token
  66. $module = mt_rand(100000,999999);
  67. $token = base64_encode($module.'#$@%!^*/'.time().'/'.$userInfo['id']);
  68. // 更新用户状态
  69. $param = [
  70. 'token' => $token,
  71. 'expire_time' => time(),
  72. ];
  73. db('accounts')->where('id', $user_id)->update($param);
  74. return json(['code' => 1, 'data' => url('user/index'), 'msg' => '注册成功']);
  75. }
  76. }
  77. }