PhoneUser.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\wap\model\user;
  12. use basic\ModelBasic;
  13. use service\QrcodeService;
  14. use think\Cookie;
  15. use think\Session;
  16. use traits\ModelTrait;
  17. use service\SystemConfigService;
  18. /**h5 用户记录表
  19. * Class PhoneUser
  20. * @package app\wap\model\user
  21. */
  22. class PhoneUser extends ModelBasic
  23. {
  24. use ModelTrait;
  25. /**获取手机号
  26. * @param $uid
  27. * @return mixed
  28. */
  29. public static function UidToPhone($uid)
  30. {
  31. return self::where('uid', $uid)->value('phone');
  32. }
  33. /**手机号登录、注册
  34. * @param $phone
  35. * @param $request
  36. * @return array|bool
  37. */
  38. public static function UserLogIn($phone, $request)
  39. {
  40. $isfollow = false;
  41. self::startTrans();
  42. try {
  43. $name = '__login_phone_number';
  44. if (self::be(['phone' => $phone])) {
  45. $user = self::where('phone', $phone)->find();
  46. $user->last_ip = $request->ip();
  47. $user->last_time = time();
  48. if ($user->uid) {
  49. Session::set('loginUid', $user->uid, 'wap');
  50. }
  51. $userinfo = User::where('uid', $user->uid)->find();
  52. if (!$userinfo->status) return self::setErrorInfo('账户已被禁止登录');
  53. $user->save();
  54. } else {
  55. $userinfo = User::where(['phone' => $phone, 'is_h5user' => 0])->find();
  56. if ($userinfo && !$userinfo->status) return self::setErrorInfo('账户已被禁止登录');
  57. if (!$userinfo) $userinfo = User::set([
  58. 'nickname' => $phone,
  59. 'pwd' => md5(123456),
  60. 'avatar' => '/system/images/user_log.jpg',
  61. 'account' => $phone,
  62. 'phone' => $phone,
  63. 'is_h5user' => 1,
  64. ]);
  65. if (!$userinfo) return self::setErrorInfo('用户信息写入失败', true);
  66. Session::set('loginUid', $userinfo['uid'], 'wap');
  67. $user = self::set([
  68. 'phone' => $phone,
  69. 'avatar' => '/system/images/user_log.jpg',
  70. 'nickname' => $phone,
  71. 'uid' => $userinfo['uid'],
  72. 'add_ip' => $request->ip(),
  73. 'add_time' => time(),
  74. 'pwd' => md5(123456),
  75. ]);
  76. if (!$user) return self::setErrorInfo('手机用户信息写入失败', true);
  77. }
  78. $isfollow = $userinfo['is_h5user'] ? false : true;
  79. Cookie::set('__login_phone', 1);
  80. Cookie::set('is_login', 1);
  81. Session::set($name, $phone, 'wap');
  82. Session::set('__login_phone_num' . $userinfo['uid'], $phone, 'wap');
  83. $res['url'] = SystemConfigService::get('wechat_qrcode');
  84. $res['id'] = 0;
  85. self::commit();
  86. return ['userinfo' => $user, 'url' => $res['url'], 'qcode_id' => $res['id'], 'isfollow' => $isfollow];
  87. } catch (\Exception $e) {
  88. return self::setErrorInfo($e->getMessage());
  89. }
  90. }
  91. /**用户注册账号、找回密码
  92. * @param $account
  93. * @param $pwd
  94. * @param $type
  95. * @param $request
  96. * @return bool
  97. */
  98. public static function userRegister($account, $pwd, $type, $request)
  99. {
  100. self::beginTrans();
  101. try {
  102. if ($type == 2) {
  103. $user = self::where('phone', $account)->find();
  104. if (!$user) return self::setErrorInfo('您需要先注册h5或pc账号', true);
  105. $userinfo = User::where(['phone' => $account])->find();
  106. if (!$userinfo) return self::setErrorInfo('您要找回的账号不存在', true);
  107. if (!$userinfo->status) return self::setErrorInfo('账户已被禁止登录');
  108. if ($user['pwd'] == $pwd || $userinfo['pwd'] == $pwd) return self::setErrorInfo('新密码和旧密码重复', true);
  109. $res1 = User::where(['phone' => $account])->update(['pwd' => $pwd]);
  110. $res2 = self::where(['phone' => $account])->update(['pwd' => $pwd]);
  111. $res = $res1 && $res2;
  112. self::checkTrans($res);
  113. if ($res) {
  114. return true;
  115. } else {
  116. return false;
  117. }
  118. } else if ($type == 1) {
  119. $userinfo = User::where(['phone' => $account])->find();
  120. if ($userinfo && !$userinfo->status) return self::setErrorInfo('账户已被禁止登录');
  121. if (!$userinfo) $userinfo = User::set([
  122. 'nickname' => $account,
  123. 'pwd' => $pwd,
  124. 'avatar' => '/system/images/user_log.jpg',
  125. 'account' => $account,
  126. 'phone' => $account,
  127. 'is_h5user' => 1,
  128. ]);
  129. if (!$userinfo) return self::setErrorInfo('用户信息写入失败', true);
  130. $user = self::where('phone', $account)->find();
  131. if ($user) return self::setErrorInfo('账号已被使用', true);
  132. $user = self::set([
  133. 'phone' => $account,
  134. 'avatar' => '/system/images/user_log.jpg',
  135. 'nickname' => $account,
  136. 'uid' => $userinfo['uid'],
  137. 'add_ip' => $request->ip(),
  138. 'add_time' => time(),
  139. 'pwd' => $pwd,
  140. ]);
  141. if (!$user) return self::setErrorInfo('手机用户信息写入失败', true);
  142. self::commitTrans();
  143. return true;
  144. }
  145. } catch (\Exception $e) {
  146. return self::setErrorInfo($e->getMessage());
  147. }
  148. }
  149. }