getRegisterConfig($this->site_id, 'shop'); if (strstr($config_info['data']['value']['login'], 'username') === false) return $this->response($this->error([], "用户名登录未开启!")); // $auth_info = Session::get("auth_info"); // if (!empty($auth_info)) { // $this->params = array_merge($this->params, $auth_info); // } // 校验验证码 $config_model = new Config(); $info = $config_model->getCaptchaConfig(); if($info['data']['value']['shop_reception_login'] == 1){ $captcha = new Captcha(); $check_res = $captcha->checkCaptcha(); if ($check_res['code'] < 0) return $this->response($check_res); } // 登录 $login = new LoginModel(); if (empty($this->params["password"])) return $this->response($this->error([], "密码不可为空!")); $res = $login->login($this->params); //生成access_token if ($res['code'] >= 0) { $token = $this->createToken($res['data']['member_id']); return $this->response($this->success(['token' => $token])); } return $this->response($res); } /*** * 第三方登录 * @return array|string|void */ public function third_login() { $login=new LoginModel(); switch (input('app_type')) { case 'wechat': //微信公众号 $appType=input('app_type', 'wechat'); $wechat = new \addon\wechat\model\Wechat($this->site_id, $appType); $weInfo = $wechat->getAuthByCode($this->params); if($weInfo['code']>=0){ $res=$login->ThirdLogin(array_merge($this->params,$weInfo['data']),$this->site_id); }else{ return $this->response($this->error($weInfo)); } break; case 'weapp'://小程序登录 $appType=input('app_type', 'weapp'); $wechat = new \addon\weapp\model\Weapp($this->site_id, $appType); $res = $wechat->authCodeToOpenid($this->params); // $res['data']['openid']='66666666'; // $this->params['source_member']=1; if($res['code']==0){ $res=$login->ThirdLogin(array_merge($this->params,$res['data']),$this->site_id); } break; case 'toutiao': //抖音头条 $appType=input('app_type', 'toutiao'); $code=input('code'); $toutiao=new \addon\toutiao\model\Toutiao(request()->siteid(), $appType); $info=$toutiao->getSession($code); $res=$login->ThirdLogin(array_merge($this->params,$info['data']),$this->site_id); break; case 'qq': $qq_model = new QqminCode($this->params['site_id']); break; case 'aliapp': $memberInfo = [ 'openid' => time() ]; break; default: $memberInfo = []; } if(empty($res['code'])){ $memberInfo['token']=$this->createToken($res['member_id']); $memberInfo['userInfo']=$res; if (isset($res['is_register'])) $memberInfo['is_register'] = 1; return $this->response($this->success($memberInfo)); }else{ return $this->response($this->error($res)); } } /** * 手机号授权登录 */ public function mobileAuth() { $decrypt_data = event('DecryptData', $this->params, true); if ($decrypt_data[ 'code' ] < 0) return $this->response($decrypt_data); $this->params[ 'mobile' ] = $decrypt_data[ 'data' ][ 'purePhoneNumber' ]; $register = new RegisterModel(); $exist = $register->mobileExist($this->params[ "mobile" ], $this->site_id); if ($exist) { $login = new LoginModel(); $res = $login->mobileLogin($this->params); if ($res[ 'code' ] >= 0) { $token = $this->createToken($res[ 'data' ][ 'member_id' ]); $res = $this->success([ 'token' => $token ]); } } else { $res = $register->mobileRegister($this->params); if ($res[ 'code' ] >= 0) { $token = $this->createToken($res[ 'data' ]); $res = $this->success([ 'token' => $token, 'is_register' => 1 ]); } } return $this->response($res); } /** * 第三方登录 */ public function auth() { $login = new LoginModel(); $res = $login->authLogin($this->params); //生成access_token if ($res['code'] >= 0) { $token = $this->createToken($res['data']['member_id']); $data = [ 'token' => $token ]; if (isset($res['data']['is_register'])) $data['is_register'] = 1; return $this->response($this->success($data)); } return $this->response($res); } /** * 检测openid是否存在 */ public function openidIsExits() { $login = new LoginModel(); $res = $login->openidIsExits($this->params); return $this->response($res); } /** * 手机动态码登录 */ public function mobile() { $config = new ConfigModel(); $config_info = $config->getRegisterConfig($this->site_id, 'shop'); if (strstr($config_info['data']['value']['login'], 'mobile') === false) return $this->response($this->error([], "动态码登录未开启!")); $key = $this->params['key']; $verify_data = Cache::get($key); if ($verify_data["mobile"] == $this->params["mobile"] && $verify_data["code"] == $this->params["code"]) { $register = new RegisterModel(); $exist = $register->mobileExist($this->params["mobile"], $this->site_id); if ($exist) { $login = new LoginModel(); $res = $login->mobileLogin($this->params); if ($res['code'] >= 0) { $token = $this->createToken($res['data']['member_id']); $res = $this->success(['token' => $token]); } } else { $res = $this->error("", "该手机号未注册"); } } else { $res = $this->error("", "手机动态码不正确"); } return $this->response($res); } /** * 获取手机号登录验证码 * @throws Exception */ public function mobileCode() { // 校验验证码 $config_model = new Config(); $info = $config_model->getCaptchaConfig(); if($info['data']['value']['shop_reception_login'] == 1){ $captcha = new Captcha(); $check_res = $captcha->checkCaptcha(false); if ($check_res['code'] < 0) return $this->response($check_res); } $mobile = $this->params['mobile']; if (empty($mobile)) return $this->response($this->error([], "手机号不可为空!")); $mobile_code='login_mobile_code_'.$mobile; if(Cache::get($mobile_code)) return $this->response($this->error("", "重复发送请稍后再试")); $register = new RegisterModel(); $exist = $register->mobileExist($this->params["mobile"], $this->site_id); if (!$exist) return $this->response($this->error([], "该手机号未注册!")); $code = str_pad(random_int(1, 9999), 4, 0, STR_PAD_LEFT);// 生成4位随机数,左侧补0 $message_model = new Message(); $res = $message_model->sendMessage(["mobile" => $mobile, "site_id" => $this->site_id, "support_type" => ['sms'], "code" => $code, "keywords" => "LOGIN_CODE"]); if ($res["code"] >= 0) { //将验证码存入缓存 $key = 'login_mobile_code_' . md5(uniqid(null, true)); Cache::tag("login_mobile_code")->set($key, ['mobile' => $mobile, 'code' => $code], 600); Cache::tag("login_mobile_code")->set('login_mobile_code_'.$mobile, time(), 600); return $this->response($this->success(["key" => $key])); } else { return $this->response($res); } } /** * 获取第三方首次扫码登录绑定/注册手机号码验证码 手机号码存不存在都可以发送 新增2021.06.18 * captcha_id 验证码id * captcha_code 验证码 * mobile 手机号码 */ public function getMobileCode() { // 校验验证码 start $captcha = new Captcha(); $check_res = $captcha->checkCaptcha(false); if ($check_res['code'] < 0) return $this->response($check_res); // 校验验证码 end $mobile = $this->params['mobile']; if (empty($mobile)) return $this->response($this->error([], "手机号不可为空!")); $register = new RegisterModel(); $exist = $register->mobileExist($this->params["mobile"], $this->site_id); //判断该手机号码是否已绑定wx_openid // $opneid_exist = $register->openidExist($this->params["mobile"], $this->site_id); // if ($opneid_exist) return $this->response($this->error([], "该手机号已绑定其他微信公众号!")); if ($exist){ $keywords = 'LOGIN_CODE'; }else{ $keywords = 'REGISTER_CODE'; } $code = str_pad(random_int(1, 9999), 4, 0, STR_PAD_LEFT);// 生成4位随机数,左侧补0 $message_model = new Message(); $res = $message_model->sendMessage(["mobile" => $mobile, "site_id" => $this->site_id, "support_type" => ['sms'], "code" => $code, "keywords" => $keywords]); // $code = 8888;// 生成4位随机数,左侧补0 // $res["code"]=0; if ($res["code"] >= 0) { // if ($res["code"]) { //将验证码存入缓存 $key = 'login_mobile_code_' . md5(uniqid(null, true)); Cache::tag("login_mobile_code")->set($key, ['mobile' => $mobile, 'code' => $code], 600); return $this->response($this->success(["key" => $key])); // return $this->response($this->success(["key" => $key,"code"=>$code])); } else { return $this->response($res); } } /** * 验证token有效性 */ public function verifyToken(){ $token = $this->checkToken(); if ($token['code'] < 0) return $this->response($token); return $this->response($this->success()); } /** * 检测登录 * @return false|string */ public function checkLogin() { $key = $this->params[ 'key' ]; $cache = Cache::get('wechat_' . $key); if (!empty($cache)) { if (isset($cache[ 'openid' ]) && !empty($cache[ 'openid' ])) { $login = new LoginModel(); $data = [ 'wx_openid' => $cache[ 'openid' ], 'site_id' => $this->site_id ]; $is_exits = $login->openidIsExits($data); if ($is_exits[ 'data' ]) { // 存在即登录 $res = $login->authLogin($data); //生成access_token if ($res[ 'code' ] >= 0) { $token = $this->createToken($res[ 'data' ][ 'member_id' ]); // Session::set($this->params[ 'app_type' ] . "_token_" . $this->site_id, $token); // Session::set($this->params[ 'app_type' ] . "_member_id_" . $this->site_id, $res[ 'data' ][ 'member_id' ]); return $this->response($this->success([ 'token' => $token ])); } return $this->response($res); } else { // 将openid存入session Session::set("auth_info",[ 'wx_openid'=>$cache['openid'], 'nickname'=>$cache['nickname'], 'headimg'=>$cache['headimgurl'] ]); Cache::set('wechat_' . $key, null); return $this->response($this->success()); } } elseif (time() > $cache[ 'expire_time' ]) { Cache::set('wechat_' . $key, null); return $this->response($this->error('', '已失效')); } else { return $this->response($this->error('', 'no login')); } } else { return $this->response($this->error('', '已失效')); } } }