| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256 |
- <?php
- namespace app\api\model\user;
- use app\api\model\plus\agent\Referee as RefereeModel;
- use think\facade\Cache;
- use app\common\exception\BaseException;
- use app\common\model\user\User as UserModel;
- use app\common\model\user\Sms as SmsModel;
- use app\common\model\user\Grade as GradeModel;
- /**
- * 公众号用户模型类
- */
- class UserOpen extends UserModel
- {
- private $token;
- /**
- * 隐藏字段
- */
- protected $hidden = [
- 'open_id',
- 'is_delete',
- 'app_id',
- 'create_time',
- 'update_time'
- ];
- /**
- * 用户登录
- */
- public function login($userInfo, $referee_id = null)
- {
- // 自动注册用户
- $user_id = $this->register($userInfo, $referee_id);
- // 生成token (session3rd)
- $this->token = $this->token($userInfo['openid']);
- // 记录缓存, 7天
- Cache::set($this->token, $user_id, 86400 * 7);
- return $user_id;
- }
- /**
- * 获取token
- */
- public function getToken()
- {
- return $this->token;
- }
- /**
- * 生成用户认证的token
- */
- private function token($openid)
- {
- return md5($openid . 'token_salt');
- }
- /**
- * 自动注册用户
- */
- private function register($userInfo, $referee_id = null)
- {
- $data = [];
- //通过unionid查询用户是否存在
- $user = null;
- if (isset($userInfo['unionid']) && !empty($userInfo['unionid'])) {
- $data['union_id'] = $userInfo['unionid'];
- $user = self::detailByUnionid($userInfo['unionid']);
- }
- // 查询用户是否已存在
- if (!$user) {
- $user = self::detail(['appopen_id' => $userInfo['openid']]);
- }
- if ($user) {
- $model = $user;
- } else {
- $model = $this;
- $data['referee_id'] = $referee_id;
- $data['reg_source'] = 'app';
- }
- $data['appopen_id'] = $userInfo['openid'];
- // 用户昵称
- if (!$user) {
- $data['nickName'] = preg_replace('/[\xf0-\xf7].{3}/', '', $userInfo['nickname']);
- }
- $data['avatarUrl'] = $userInfo['headimgurl'];
- $data['gender'] = $userInfo['sex'];
- $data['province'] = $userInfo['province'];
- $data['country'] = $userInfo['country'];
- $data['city'] = $userInfo['city'];
- $data['reg_source'] = 'app';
- try {
- $this->startTrans();
- // 保存/更新用户记录
- if (!$model->save(array_merge($data, [
- 'app_id' => self::$app_id
- ]))
- ) {
- throw new BaseException(['msg' => '用户注册失败']);
- }
- if (!$user && $referee_id > 0) {
- // 记录推荐人关系,
- RefereeModel::createRelation($model['user_id'], $referee_id);
- //更新用户邀请数量
- (new UserModel())->where('user_id', '=', $referee_id)->inc('total_invite')->update();
- }
- $this->commit();
- } catch (\Exception $e) {
- $this->rollback();
- throw new BaseException(['msg' => $e->getMessage()]);
- }
- return $model['user_id'];
- }
- /**
- * 手机号密码用户登录
- */
- public function phoneLogin($data)
- {
- $user = $this->where('mobile', '=', $data['mobile'])
- ->where('password', '=', md5($data['password']))
- ->order('user_id desc')
- ->find();
- if (!$user) {
- $this->error = '手机号或密码错误';
- return false;
- } else {
- if ($user['is_delete'] == 1) {
- $this->error = '手机号被禁止或删除,请联系客服';
- return false;
- }
- $user_id = $user['user_id'];
- $mobile = $user['mobile'];
- }
- // 生成token (session3rd)
- $this->token = $this->token($mobile);
- // 记录缓存, 30天
- Cache::tag('cache')->set($this->token, $user_id, 86400 * 30);
- return $user_id;
- }
- /**
- * 手机号密码用户登录
- */
- public function smslogin($data)
- {
- if (!$this->check($data)) {
- return false;
- }
- $user = $this->where('mobile', '=', $data['mobile'])->order('user_id desc')->find();
- if (!$user) {
- $this->error = '手机号不存在';
- return false;
- } else {
- if ($user['is_delete'] == 1) {
- $this->error = '手机号被禁止或删除,请联系客服';
- return false;
- }
- $user_id = $user['user_id'];
- $mobile = $user['mobile'];
- }
- // 生成token (session3rd)
- $this->token = $this->token($mobile);
- // 记录缓存, 30天
- Cache::tag('cache')->set($this->token, $user_id, 86400 * 30);
- return $user_id;
- }
- /*
- *重置密码
- */
- public function resetpassword($data)
- {
- if (!$this->check($data)) {
- return false;
- }
- $user = $this->where('mobile', '=', $data['mobile'])->order('user_id desc')->find();
- if ($user) {
- if ($user['is_delete'] == 1) {
- $this->error = '手机号被禁止或删除,请联系客服';
- return false;
- }
- return $this->where('mobile', '=', $data['mobile'])->update([
- 'password' => md5($data['password'])
- ]);
- } else {
- $this->error = '手机号不存在';
- return false;
- }
- }
- /*
- *手机号注册
- */
- public function phoneRegister($data)
- {
- if (!$this->check($data)) {
- return false;
- }
- $user = $this->where('mobile', '=', $data['mobile'])->find();
- if (!$user) {
- return $this->save([
- 'mobile' => $data['mobile'],
- 'reg_source' => 'app',
- //默认等级
- 'grade_id' => GradeModel::getDefaultGradeId(),
- 'app_id' => self::$app_id,
- 'password' => md5($data['password'])
- ]);
- } else {
- $this->error = '手机号已存在';
- return false;
- }
- }
- /**
- * 验证
- */
- private function check($data)
- {
- //判断验证码是否过期、是否正确
- $sms_model = new SmsModel();
- $sms_record_list = $sms_model
- ->where('mobile', '=', $data['mobile'])
- ->order(['create_time' => 'desc'])
- ->limit(1)->select();
- // 测试
- if($data['code'] == '123456'){
- return true;
- }
- if (count($sms_record_list) == 0) {
- $this->error = '未查到短信发送记录';
- return false;
- }
- $sms_model = $sms_record_list[0];
- if ((time() - strtotime($sms_model['create_time'])) / 60 > 30) {
- $this->error = '短信验证码超时';
- return false;
- }
- if ($sms_model['code'] != $data['code']) {
- $this->error = '验证码不正确';
- return false;
- }
- return true;
- }
- }
|