suser = new SuserApi; } public function asd(){ var_dump(sendMail("894827077@qq.com","测试啊","成都市"));die; } /** * 登录 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function login(){ if (IS_POST) { $post = I('post.'); $account = $post['phone']; $password = $post['password']; $member = new MemberApi(); /*是否开启Ucenter*/ if( C('UC_OPEN')==1 ) { $username = $account; //Ucenter登录 list($uc_uid, $uc_username, $uc_password, $uc_email) = uc_user_login($username,$password); if($uc_uid > 0) { //1.登录成功,验证在本地是否有此账号 $user_res = M('user','tab_')->where(['account'=>$uc_username])->find(); if(!empty($user_res)){//本地存在账号,验证密码直接登录 $res = $this->suser->login($account,$password); if($res > 0) { $data=array( 'status' => 1, 'msg' => '登录成功', ); } else { switch($res) { case -1000: $error = '账号不存在'; break; case -10021: $error = '密码错误!'; break; case -1001: $error = '账号被禁用,请联系客服!'; break; default: $error = '未知错误!'; break; } $data=array( 'status' => 0, 'msg' => $error, ); } echo json_encode($data);die(); }else{//本地不存在账号,新增账号并登录 $resdata=array(); $resdata['account']=trim($username); $resdata['nickname']=trim($username); $resdata['password']=$password; $resdata['register_way']=3; $resdata['register_type']=1; $resdata['promote_id']=0; $resdata['promote_account']='UC用户'; $resdata['parent_id']=0; $resdata['parent_name']=''; $resdata['phone']=''; $resdata['real_name']=''; $resdata['idcard']=''; $res = $this->suser->register_array($resdata); if($res > 0 ){ $res = $this->suser->login($account,$password); if($res > 0) { $data=array( 'status' => 1, 'msg' => '登录成功', ); } else { switch($res) { case -1000: $error = '账号不存在'; break; case -10021: $error = '密码错误!'; break; case -1001: $error = '账号被禁用,请联系客服!'; break; default: $error = '未知错误!'; break; } $data=array( 'status' => 0, 'msg' => $error, ); } echo json_encode($data);die(); }else{ $msg = $res == -3 ?"账号已存在":"身份证被占用"; return $this->ajaxReturn(array('status'=>0,'msg'=>$msg)); } } } elseif($uc_uid == -1) { //用户不存在,验证本地用户账号密码 $res = $this->suser->login($account,$password); if($res > 0) { $data=array( 'status' => 1, 'msg' => '登录成功', ); //同步ucenter注册 cus_uc_register($username,$password,$username.'@vlcms.com'); } else { switch($res) { case -1000: $error = '账号不存在'; break; case -10021: $error = '密码错误!'; break; case -1001: $error = '账号被禁用,请联系客服!'; break; default: $error = '未知错误!'; break; } $data=array( 'status' => 0, 'msg' => $error, ); } echo json_encode($data);die(); } elseif($uc_uid == -2) { //密码错误 $this->ajaxReturn(array('status' => -1002, 'code'=>-10021,'msg' => '密码错误')); } else { //登录失败 } } $res = $this->suser->login($account,$password);file_put_contents(dirname(__FILE__) . '/login_res_text.txt',json_encode([$res])); if($res > 0) { $promoteId = I('post.promote_id'); $promoteId = intval($promoteId); if ($promoteId > 0) { $wherePromote['id'] = $promoteId; $promoteData = M('Promote','tab_')->field('id,account')->where($wherePromote)->find(); if (!empty($promoteData)) { $whereUser['account'] = $account; $whereUser['_logic'] = 'or'; $whereUser['mobile_phone'] = $account; $userData = M('User', 'tab_')->where($whereUser)->find(); if (!empty($userData)) { if (empty($userData['promote_id'])) { $saveData['promote_id'] = $promoteId; $saveData['promote_account'] = $promoteData['account']; $saveRes = M('User', 'tab_')->where(array('id'=>$userData['id']))->save($saveData); if ($saveRes) { $data = array( 'status' => 2, 'msg' => '登录成功!绑定成功', ); } else { $data = array( 'status' => 0, 'msg' => '绑定失败', ); } } else { if ($userData['promote_id'] == $promoteId) { $data = array( 'status' => 2, 'msg' => '登录成功!绑定成功', ); } else { $data = array( 'status' => 2, 'msg' => '登录成功', ); } } } else { $data = array( 'status' => 0, 'msg' => '数据异常', ); } } else { $data = array( 'status' => 0, 'msg' => '数据异常', ); } } else { $data=array( 'status' => 1, 'msg' => '登录成功', ); } } else { switch($res) { case -1000: $error = '账号不存在'; break; case -10021: $error = '密码错误!'; break; case -1001: $error = '账号被禁用,请联系客服!'; break; default: $error = '未知错误!'; break; } $data=array( 'status' => 0, 'msg' => $error, ); } echo json_encode($data);die(); } else { $pid = I('get.pid', 0); $gid = I('get.gid', 0); if ($pid > 0 || $gid > 0) { cookie('pgInfo', json_encode(['pid' => $pid, 'gid' => $gid]), 3600 * 24); } if($_REQUEST['url']){ $this->assign('url',base64_decode(base64_decode($_REQUEST['url']))); }else{ $this->assign('url',U('User/index')); } $this->display(); } } /** * 注册步骤一 填写用户名和密码 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function step(){ if(IS_POST){ $post = I('post.'); $account = $post['nickname']; $password = $post['password']; $sex = $post['sex']; if (empty($account)) { echo json_encode(array('status'=>0,'msg'=>'请填写昵称'));exit; } if (empty($password)) { echo json_encode(array('status'=>0,'msg'=>'请输入密码'));exit; } $promoteId = I('post.promote_id'); $promoteId = intval($promoteId); if ($promoteId > 0) { $gameId = intval(I('post.game_id')); $safeinfo = array('nickname' => $account, 'password' => $password, 'sex' => $sex ,'status' => 1,'promote_id' => $promoteId, 'game_id' => $gameId); } else { $safeinfo = array('nickname' => $account, 'password' => $password, 'sex' => $sex ,'status' => 1); } session('safeinfo',$safeinfo); $url = U('register'); echo json_encode(array('status'=>1,'msg'=>$url)); } else{ $this->display(); } } /** * 注册 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function register(){ $safeinfo = session('safeinfo'); if($safeinfo['status']==1){ if(IS_POST){ $post = I('post.'); $phone = $post['phone']; $safecode = $post['code']; $nickname = $safeinfo['nickname']; $password = $safeinfo['password']; $sex = $safeinfo['sex']; $this->checksafecode($phone,$safecode,false); /**是否开启ucenter**/ if(C('UC_OPEN')==1){ //Ucenter注册 //1.验证本平台是否存在账号 $is_user_info = M('user','tab_')->where(['account'=>$phone])->find(); if(!empty($is_user_info)){ return $this->ajaxReturn(array('status'=>0,'msg'=>'用户名已存在')); } //2.验证其他平台是否存在账号 $domain = C('UC_OTHER_WEB_URL'); if(!empty($domain)){ $url = "http://{$domain}/Api/user/checkUserName?account={$phone}"; $check_res = json_decode(file_get_contents($url),true); if($check_res['status']==0){ $this->ajaxReturn(array('status'=>0,'msg'=>'注册失败,用户名已存在'));exit; } } //3.ucenter注册账号 $ucresult = uc_user_checkname($phone); if($ucresult == -1) { $this->ajaxReturn(array('status'=>0,'msg'=>'用户名不合法'));exit; } elseif($ucresult == -2) { $this->ajaxReturn(array('status'=>0,'msg'=>'包含要允许注册的词语'));exit; } elseif($ucresult == -3) { $this->ajaxReturn(array('status'=>0,'msg'=>'用户名已经存在'));exit; }else{ //同步ucenter注册 cus_uc_register($phone,$password,$phone.'@vlcms.com'); } } $register_way = 4; $register_type = 2; switch ($sex) { case '0': $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/logoo.png'; break; default: $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/head_women@3x.png'; break; } if (!preg_match("/^1[34578]\d{9}$/", $phone)) { echo json_encode(['status' => 0,'msg' => '手机号格式不正确']); die; } if (!preg_match("/^[a-zA-Z0-9]{6,15}+$/", $password)) { echo json_encode(['status' => 0,'msg' => '密码格式不正确']); die; } $pgInfo = strval(cookie('pgInfo')); Log::write('register:' . date('Y-m-d H:i:s') . ' ---- ' . json_encode($_POST) . ' --- ' . $pgInfo, 'INFO'); if (isset($_POST['promote_id']) && !empty($_POST['promote_id'])) { $pid = $this->suser->register($phone,$password,$phone,$register_way,$register_type,$_POST['promote_id'],$_POST['promote_account'],$sex,$nickname,$head_img); } else { $pid = $this->suser->register($phone,$password,$phone,$register_way,$register_type,'','',$sex,$nickname,$head_img); } if($pid > 0){ if (empty($safeinfo['promote_id'])) { $data = array( 'status' => 1, 'msg' => '注册成功', 'url' => U('Index/index'), ); } else { $data = array( 'status' => 1, 'msg' => '注册成功', 'url' => U('User/login', array('pid' => $safeinfo['promote_id'], 'gid' => $safeinfo['game_id'])), ); } session('safeinfo',null); } else{ $data = array( 'status' => $pid, 'msg' => '注册失败', ); } echo json_encode($data); } else{ $pid = I('get.pid', 0); $gid = I('get.gid', 0); if ($pid > 0 || $gid > 0) { cookie('pgInfo', json_encode(['pid' => $pid, 'gid' => $gid]), 3600 * 24); } if ($_REQUEST['url']) { $url= base64_decode($_REQUEST['url']); } else { $url=$_SERVER['HTTP_REFERER']; } $this->assign('url',$url); $this->display(); } }else{ $this->redirect(U('step')); } } /** * 账号注册 * @return [type] [description] * @author 郭家屯 */ public function step1(){ if(IS_POST){ $post = I('post.'); $account = $post['account']; $nickname = $post['nickname']; $password = $post['password']; $sex = $post['sex']; $pgInfo = strval(cookie('pgInfo')); Log::write('step1:' . date('Y-m-d H:i:s') . ' ---- ' . json_encode($post) . ' --- ' . $pgInfo, 'INFO'); /**是否开启ucenter**/ if(C('UC_OPEN')==1){ //Ucenter注册 //1.验证本平台是否存在账号 $is_user_info = M('user','tab_')->where(['account'=>$_POST['account']])->find(); if(!empty($is_user_info)){ return $this->ajaxReturn(array('status'=>0,'msg'=>'用户名已存在')); } //2.验证其他平台是否存在账号 $domain = C('UC_OTHER_WEB_URL'); if(!empty($domain)){ $url = "http://{$domain}/Api/user/checkUserName?account={$_POST['account']}"; $check_res = json_decode(file_get_contents($url),true); if($check_res['status']==0){ $this->ajaxReturn(array('status'=>0,'msg'=>'注册失败,用户名已存在'));exit; } } //3.ucenter注册账号 $ucresult = uc_user_checkname($_POST['account']); if($ucresult == -1) { $this->ajaxReturn(array('status'=>0,'msg'=>'用户名不合法'));exit; } elseif($ucresult == -2) { $this->ajaxReturn(array('status'=>0,'msg'=>'包含要允许注册的词语'));exit; } elseif($ucresult == -3) { $this->ajaxReturn(array('status'=>0,'msg'=>'用户名已经存在'));exit; }else{ //同步ucenter注册 cus_uc_register($_POST['account'],$_POST['password'],$_POST['account'].'@vlcms.com'); } } $register_way = 4; $register_type = 1; switch ($sex) { case '0': $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/logoo.png'; break; default: $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/head_women@3x.png'; break; } $map['account'] = $account; $map['phone'] = $account; $map['_logic'] = "or"; $is_setting = M("user","tab_")->where($map)->field("id")->find(); if($is_setting){ echo json_encode(array('status'=>0,'msg'=>'账号已存在'));exit; } if (!preg_match("/^[a-z\d]{6,15}$/i", $account)) { echo json_encode(['status' => 0,'msg' => '账号格式不正确']); die; } if (!preg_match("/^[a-zA-Z0-9]{6,15}+$/", $password)) { echo json_encode(['status' => 0,'msg' => '密码格式不正确']); die; } $pid = $this->suser->register($account,$password,'',$register_way,$register_type,'','',$sex,$nickname,$head_img); if($pid > 0){ $promoteId = I('post.promote_id'); $promoteId = intval($promoteId); if ($promoteId > 0) { $gameId = intval(I('post.game_id')); $data = array( 'status' => 1, 'msg' => '注册成功', 'url' => U('User/login', array('pid' => $promoteId, 'gid' => $gameId)), ); } else { $data = array( 'status' => 1, 'msg' => '注册成功', 'url' => U('Index/index'), ); } } else{ $data = array( 'status' => $pid, 'msg' => '注册失败', ); } echo json_encode($data); exit; } $this->display(); } /** * 发动手机验证码 */ public function telsafecode($phone='',$delay=10,$flag=true) { $result = R('Common/Sms/send_sms_code',array($phone,$delay,false)); if($result['code']==200) { $data['status'] = 1; $data['data'] = $result['data']; } else { $data['status'] = 0; } $data['msg'] = $result['msg']; echo json_encode($data); exit; } /** * 发送安全码 */ public function sendsafecode($phone,$delay=10) { if (IS_POST) { $res = $this->suser->checkAccount($phone); if (!$res) { echo json_encode(array('status'=>0,'msg'=>'手机号码被占用'));exit; } $this->telsafecode($phone); exit; } else{ echo json_encode(array('status'=>0,'msg'=>'请按正确的流程'));exit; } } /** * 手机安全码验证 * @param bool $flag true 用于直接异步请求 false 用于方法调用 * @param [type] $vcode [description] */ public function checksafecode($phone,$vcode,$flag=true) { $result = R('Common/Sms/verify_sms_code',array($phone,$vcode,false)); if($result['code']==200) { $data['status'] = 1; if($flag) { echo json_encode($data);exit; } } else { $data['status'] = 0; $data['msg'] = $result['msg']; echo json_encode($data);exit; } } /** * 忘记密码 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function forget(){ if(IS_POST){ $phone = $_POST['phone']; $this->checksafecode($phone,$_REQUEST['code'],false); $this->success('验证成功',U('User/forget1',array('phone'=>$phone))); }else{ $this->display(); } } public function forget1(){ if(IS_POST){ $new_pwd = $_REQUEST['new_pwd']; $u_uid['phone'] = $_REQUEST['phone']; $result = M('user','tab_')->where($u_uid)->setField('password',think_ucenter_md5($new_pwd, UC_AUTH_KEY)); if($result != false) { $this->success("修改成功",U('User/login')); }elseif($result === 0){ $this->error("新密码和旧密码一致,请重新输入"); }else{ $this->error("修改失败"); } }else{ $this->display(); } } /** * 忘记密码发送短信 * @param $account * author: xmy 280564871@qq.com */ public function forget_send_msg($account) { $data = D("User")->getUserInfo($account); if(C('UC_SET')==1){ $uc = new Ucservice(); $data_uc = $uc->get_uc($account); if (empty($data) && !empty($data_uc)) { $this->error("UC用户不支持"); } } if (empty($account)) { echo json_encode(array('status'=>0,'msg'=>'账号不存在'));exit; } elseif (empty($data['phone'])) { echo json_encode(array('status'=>0,'msg'=>'该用户未绑定手机号'));exit; } $result = $this->telsafecode($account); } /** * 判断是否登录 * @return [type] [description] */ public function islogin() { $user = $this->suser->login_info(); if($user) { if ($user['nickname']) { $account = $user['nickname']; } else { $account = $user['account']; } return $user['user_id']; } else { return 0; } } /** * 个人中心首页 * @return [type] [description] * @author wyr <840186209@qq.com> */ /* public function index() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $session = session('user_auth'); $user = D('User')->where(array('id'=>$session['user_id']))->find(); $headimg = $user['head_img']; $user['head_img'] = is_numeric($headimg)?get_cover($headimg,'path'):$headimg; $this->assign('user',$user); $this->show_sing_in($session['user_id']); $this->display(); } */ /** * 个人中心 * @author 鹿文学 */ public function index() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $user = D('User')->getInfo(); $this->assign('user',$user); $this->show_sing_in($user['id']); $this->display(); } public function show_sing_in($user_id){ $type = D('PointRecord')->getPointType("sign_in"); if(!$type){ return false; } $base_point = $type['point']; $increase_point = $type['time_of_day']; $record = D('PointRecord')->getSignInInfo($user_id,$type['id']); //计算间隔时间 $today = strtotime(date("Y-m-d")); $time = strtotime(date("Y-m-d",$record['create_time'])); $day = ($today-$time)/86400; if($day == 1){//昨日积分 + 递增积分 $add_point = $record['point'] + $increase_point; //超过7天 重新计算 if ($record['day'] >= 7) { $add_point = $base_point; $sign_day = 1; }else{ $sign_day = $record['day']; } $data['point'] = $add_point; }elseif($day == 0){ $add_point = $record['point'] + $increase_point; $data['point'] = $add_point; $sign_day = 1; }else{//基础积分 $data['point'] = $base_point; $sign_day = 0; } $this->assign('point',$data['point']); $this->assign('sign_day',$sign_day); $this->assign('day',$day); } public function sign_in(){ $user_id = $this->islogin(); $model = D('PointRecord'); $result = $model->addPointBySignIn($user_id); if($result !== false){ $data['day'] = $result; $this->success("签到成功",$data); }else{ $this->error($model->getError()); } } /** * 个人中心->编辑资料 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function userset() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); $user = D('User')->where(array('id'=>$logininfo['user_id']))->find(); if(is_numeric($user['head_img'])){ $user['head_img'] = get_cover($user['head_img'],"path"); } $this->assign('user',$user); $this->display(); } /** * 个人中心->编辑资料->修改昵称 * @return [type] [description] * @author 小纯洁 */ public function usernick() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); if(IS_POST){ $map['id'] = $logininfo['user_id']; $model = D('User')->where($map)->save(array('nickname'=>$_REQUEST['nickname'])); $this->suser->set_login_info('nickname',$_REQUEST['nickname']); if($model !== false){ $this->success("修改成功",U('User/userset')); }else{ $this->error("修改失败"); } }else{ $this->assign('user',$logininfo); $this->display(); } } /** * 个人中心->编辑资料->绑定/解除手机 * @return [type] [description] * @author 郭家屯 */ public function userphone(){ if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); $map['id'] = $logininfo['user_id']; $user = M("user","tab_")->where($map)->field("id,phone")->find(); if(IS_POST){ $code = I("post.scode"); $phone = I("post.phone"); $this->checksafecode($phone,$code,false); if(!$user['phone']){ $where['account'] = $phone; $where['phone'] = $phone; $condition['_complex'] = $where; $condition['id'] = array("neq",$user['id']); $is_user = M("user","tab_")->where($condition)->field("id")->find(); if($is_user){ echo json_encode(array('status'=>0,'msg'=>'手机号已存在,请更换手机号'));exit(); } $model = M('User','tab_')->where($map)->save(array('phone'=>$phone)); }else{ $model = M('User','tab_')->where($map)->save(array('phone'=>'')); } $this->suser->set_login_info('phone',$_REQUEST['phone']); if($model !== false){ echo json_encode(array('status'=>1,'msg'=>'修改成功','url'=>U('User/userset')));exit(); }else{ echo json_encode(array('status'=>0,'msg'=>'修改失败'));exit(); } }else{ $this->assign('user',$user); $this->display(); } } /** *发送验证码请求 * @author 郭家屯 */ public function sendvcode() { if (!IS_POST) { echo json_encode(array('status'=>0,'msg'=>'请按正确的流程'));exit; } $logininfo = $this->suser->login_info(); if($logininfo['nickname']=="Uc用户"){ echo json_encode(array('status'=>0,'msg'=>'Uc用户暂不支持'));exit(); } if(!$this->islogin()){$this->redirect('Mobile/User/login');} $phone = I('phone'); $map['id'] = $logininfo['user_id']; $user = M("user","tab_")->where($map)->field("id,phone")->find(); if(!$user['phone']){ $where['account'] = $phone; $where['phone'] = $phone; $where['_logic'] = 'OR'; $is_user = M("user","tab_")->where($where)->field("id")->find(); if($is_user){ echo json_encode(array('status'=>0,'msg'=>'手机号已存在,请更换手机号'));exit(); } } $this->telsafecode($phone); } /** * 个人中心->编辑资料->修改性别 * @return [type] [description] * @author 小纯洁 */ public function usersex() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); if(IS_POST){ $map['id'] = $logininfo['user_id']; $sex = $_REQUEST['sex']; $user = D('User')->where($map)->find(); $img_url = strstr($user['head_img'],"http://"); if($img_url){ switch ($sex) { case '0': $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/logoo.png'; break; default: $head_img = "http://".$_SERVER['HTTP_HOST'].'/Public/Mobile/images/head_women@3x.png'; break; } }else{ $head_img = $user['head_img']; } $model = D('User')->where($map)->save(array('sex'=>$sex,'head_img'=>$head_img)); if($model !== false){ $this->success("修改成功",U('User/userset')); }else{ $this->error("修改失败"); } }else{ $user = D('user')->field("sex")->find($logininfo['user_id']); $this->assign('user',$logininfo); $this->assign('sex',$user['sex']); $this->display(); } } /** * 个人中心->编辑资料->实名认证 * @return [type] [description] * @author 小纯洁 */ public function userauth() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); if(IS_POST){ $resdata['age_status'] = 0; $map['id'] = $logininfo['user_id']; if(isset($_POST['idcard'])){ $checkidcard = new \Think\Checkidcard(); $invidcard=$checkidcard->checkIdentity($_POST['idcard']); if(!$invidcard){ $this->ajaxReturn(array('status'=>-1,'info'=>'身份证号码填写不正确','url'=>U('User/userauth'))); } $cardd=M('User','tab_')->where(array('idcard'=>$_POST['idcard']))->find(); if($cardd){ $this->ajaxReturn(array('status'=>-1,'info'=>'身份证号码已被使用','url'=>U('User/userauth'))); } } if (C('tool_age.status') == 0){ $this->ajaxReturn(array('status'=>0,'info'=>'实名认证暂未开启!','url'=>U('User/userauth'))); }else{ $re = age_verify($_REQUEST['real_name'],$_REQUEST['idcard']); if ($re == 0){ $this->ajaxReturn(array('status'=>0,'info'=>'审核失败!','url'=>U('User/userauth'))); } if ($re == -1){ $this->ajaxReturn(array('status'=>0,'info'=>'短信数量已使用完!','url'=>U('User/userauth'))); } if ($re == -2){ $this->ajaxReturn(array('status'=>0,'info'=>'连接错误,请检查配置!','url'=>U('User/userauth'))); } if ($re == 1){ $resdata['age_status'] = 2;//成年 } if ($re == 2){ $resdata['age_status'] = 3;//未成年 } } if($re > 0){ $model = D('User')->where($map)->save(array('real_name'=>$_REQUEST['real_name'],'idcard'=>$_REQUEST['idcard'],'age_status'=>$resdata)); } if($model !== false){ $this->success("修改成功",U('User/userset')); }else{ $this->error("修改失败"); } }else{ $user = D('User')->where(array('id'=>$logininfo['user_id']))->find(); $this->assign('user',$user); $this->display(); } } /** * 个人中心->编辑资料->修改密码 * @return [type] [description] * @author 小纯洁 */ public function userpassword() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); if(IS_POST){ $old_pwd = $_REQUEST['old_pwd']; $new_pwd = $_REQUEST['new_pwd']; /*判断Ucenter是否打开*/ if( C('UC_OPEN')==1 ){ $username = $logininfo['account']; //修改uc密码 $ucresult = uc_user_edit($username,$_POST['old_pwd'],$_POST['new_pwd']); if($ucresult == -1) { $this->error("原始密码不正确"); } /** * 同步修改其他站点用户密码 */ $domain = C('UC_OTHER_WEB_URL'); if(!empty($domain)){ $url = "http://{$domain}/Api/user/editPassword?account={$username}&oldpsw={$_POST['old_pwd']}&newpsw={$_POST['new_pwd']}"; $aa = json_decode(file_get_contents($url),true); } } $result = D('User')->changePwd($logininfo['account'], $old_pwd, $new_pwd); if ($result == -1) { $this->error("原始密码不正确"); } elseif($result !=false) { $u_uid['account']=$logininfo['account']; M('user_pwd')->where($u_uid)->setField('password',think_encrypt($new_pwd)); $this->suser->logout(); $this->success("修改成功",U('User/login')); }elseif($result === 0){ $this->error("新旧密码一致,请重新输入"); } else{ $this->error("修改失败"); } }else{ $this->display(); } } /** * 个人中心->编辑资料->收货管理 * @return [type] [description] * @author 小纯洁 */ public function useraddresslist() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); $userData = M('UserAddress','tab_')->where(array('user_id'=>$logininfo['user_id']))->select(); $this->assign('list_data',$userData); $this->display(); } /** * 个人中心->编辑资料->收货管理->新增收货地址 * @return [type] [description] * @author 小纯洁 */ public function useraddressadd() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); if(IS_POST){ $model = M('UserAddress','tab_'); $data = $_REQUEST; $data['user_id'] = $logininfo['user_id']; $data['create_time'] = time(); $userData = M('UserAddress','tab_')->where(array('user_id'=>$logininfo['user_id']))->select(); if(isset($data['is_default'])){ $data['is_default'] = 1; $model->where(array('user_id'=>$logininfo['user_id']))->save(array('is_default'=>0)); }else{ $data['is_default'] = 0; } if($model->create($data) && $model->add()){ $this->success('添加成功',U('User/useraddresslist')); }else{ $this->error('添加失败'); } }else{ $this->display(); } } /** * 个人中心->编辑资料->收货管理->编辑收货地址 * @return [type] [description] * @author 小纯洁 */ public function useraddressedit($id=0) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo = $this->suser->login_info(); $model = M('UserAddress','tab_'); if(IS_POST){ $data = $_REQUEST; $data['user_id'] = $logininfo['user_id']; $data['id'] = $id; if(!empty($data['is_default'])){ $model->where('user_id='.$logininfo['user_id'])->save(array('is_default'=>0)); } if($model->save($data) !== false){ $this->success('编辑成功',U('User/useraddresslist')); }else{ $this->error('编辑失败'); } }else{ $data = $model->find($id); $this->assign("data",$data); $this->display(); } } /** * 个人中心->编辑资料->收货管理->删除收货地址 * @return [type] [description] * @author 小纯洁 */ public function useraddressdel($id=0) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $model = M('UserAddress','tab_'); $result = $model->where("id=".$id)->delete(); if($result !== false){ $this->success('地址删除成功',U('User/useraddresslist')); }else{ $this->error("地址删除失败"); } } /** * 个人中心->编辑资料->收货管理->设置默认收货地址 * @return [type] [description] * @author 小纯洁 */ public function setDefaultAddress($id=0,$type='setting') { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $model = M('UserAddress','tab_'); $logininfo = $this->suser->login_info(); switch ($type) { case 'setting': $map['id'] = array('neq',$id); $map['user_id'] = $logininfo['user_id']; $model->where($map)->save(array('is_default'=>0)); $result = $model->where(array('id'=> $id))->save(array('is_default'=>1)); break; case 'cancel': $result = $model->where(array('id'=> $id))->save(array('is_default'=>0)); break; } if($result !== false){ $this->success('地址删除成功'); }else{ $this->error("地址删除失败"); } } /** * 个人中心->绑币管理 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function userbindcoin() { $islogin = $this->islogin(); if($islogin){ $map['user_id'] = $islogin; $page = $page ? $page : 1; //默认显示第一页数据 $row = C('LIST_ROWS'); $data = M("user_play","tab_") ->field("game_name,game_id,bind_balance") ->where($map) ->group("game_id") ->page($page,$row) ->select(); $display = ''; $this->assign('page',$page); $this->assign('data',$data); }else{ $display = 'login'; } $this->display($display); } /** * AJAX 绑币管理加载更多 * @return [type] [description] */ public function ajaxcoin() { $p = I('post.p'); $status=0; $row = C('LIST_ROWS'); $map['user_id'] = $this->suser->login_info('user_id'); $lists = M("user_play","tab_") ->field("game_name,game_id,bind_balance") ->where($map) ->group("game_id") ->page($p,$row) ->select(); if (!empty($lists) && is_array($lists)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$p,'lists'=>$lists)); } public function recharge($pay_type=1){ if(!$this->islogin()){$this->redirect('Mobile/User/login');} $logininfo_id = $this->suser->login_info('user_id'); if(IS_POST){ $user_id = get_user_id($_REQUEST['account']); $pay_amount = $_POST['pay_amount']; if($user_id!=$logininfo_id){ $this->error('只能给自己充值'); } if($user_id == 0){$this->error('账号不存在');} if($pay_amount<0) { $this->error('金额不正确'); } $pay_amount = abs($pay_amount); //$pay_amount = 0.01; if($_REQUEST['spendType'] == 2){ $userMap['user_id'] = $user_id; $userMap['game_id'] = $_REQUEST['game_id']; $empty = M('UserPlay','tab_')->where($userMap)->find(); if(empty($empty)){ $this->error('该用户未玩过此游戏哦~'); } } $json = array( 'type' => $_REQUEST['spendType'], 'user_id' => $user_id, 'game_id' => $_REQUEST['game_id'] ); $userEntiy = get_user_entity($logininfo_id); $pay = A('Pay'); $result = $pay->recharge($pay_amount,json_encode($json),$_POST['way'],$userEntiy['promote_id']); $this->ajaxReturn($result); }else{ $game = M("game","tab_"); $map['apply_status'] = 1; $map['online_status'] = 1; $map['user_id'] = $logininfo_id; $lists = $game->field('tab_game.id,tab_game.game_name,bind_recharge_discount') ->join('tab_user_play as up on up.game_id = tab_game.id') ->where($map) ->group('tab_game.id') ->select(); $this->assign('gameList',$lists); $this->display(); } } /** * 个人中心->我的游戏 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function usergame($p=1) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $row = C('LIST_ROWS'); $map['user_id'] = $this->suser->login_info('user_id'); $data = D('DownRecord')->table('tab_down_record AS tdr') ->field('tab_game.id,tab_game.dow_status,tab_game.game_name,tab_game.game_size,tab_game.dow_num,tab_game.icon,tab_game.features,tdr.user_id,tab_game.and_dow_address,tab_game.add_game_address,tab_game.ios_dow_address,tab_game.ios_game_address,tab_game.game_score,tab_game.sdk_version') ->join("tab_game ON tdr.game_id = tab_game.id") ->where($map) ->page($page,$row) ->select(); $this->assign("data",$data); $this->assign("page",$page); $this->display(); } /** * 个人中心->我的游戏 AJAX加载更多 * @return [type] [description] * @author 小纯洁 */ public function ajaxUserGame(){ $page = I('post.p'); $status=0; $row = C('LIST_ROWS'); $map['user_id'] = $this->suser->login_info('user_id'); $data = D('DownRecord')->table('tab_down_record AS tdr') ->field('tab_game.id,tab_game.game_name,tab_game.game_size,tab_game.dow_num,tab_game.icon,tab_game.features,tdr.user_id,tab_game.and_dow_address,tab_game.add_game_address,tab_game.ios_dow_address,tab_game.ios_game_address,tab_game.game_score') ->join("tab_game ON tdr.game_id = tab_game.id") ->where($map) ->page($page,$row) ->select(); foreach ($data as $key => $value) { $data[$key]['icon'] = get_img_url($value['icon']); $data[$key]['dow_url'] = U('Down/down_file',array('game_id'=>$value['id'],'sdk_version'=>1)); } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->我的评论 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function usercomment($game_name='') { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $row = C('LIST_ROWS'); $map['status'] = 1; $map['account'] = $this->suser->login_info('account'); if(!empty($game_name)){ $game = D("Game")->where(['game_name'=>['like',"%".$game_name."%"]])->select(); if(empty($game)){ $map['game_id'] = ['in','0']; }else{ $map['game_id'] = ['in',array_column($game,"id")]; } } $data = D('Comment')->field("account,create_time,comment,game_id")->where($map)->order("create_time desc")->page($page,$row)->select(); foreach ($data as $key => $val){ $user = D("User")->getUserInfo($val['account']); $data[$key]['nickname'] = $user['nickname']; $data[$key]['head_img'] = $user['head_img']; $gameIcon = D('Game')->where('id = '.$val['game_id'])->getField('icon'); $data[$key]['game_icon'] = get_cover($gameIcon,'path'); $data[$key]['create_time'] = date("Y-m-d H:i:s",$data[$key]['create_time']); } $result['data'] = $data; $result['count'] = D('Comment')->where($map)->count(); $this->assign('data',$result['data']); $this->assign('count',$result['count']); $this->assign('page',$page); $this->display(); } /** * AJAX 我的评论加载更多 * @return [type] [description] */ public function ajaxComment() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = I('post.p'); $row = C('LIST_ROWS'); $map['status'] = 1; $map['account'] = $this->suser->login_info('account'); $data = D('Comment')->field("account,create_time,comment,game_id")->where($map)->order("create_time desc")->page($page,$row)->select(); foreach ($data as $key => $val){ $user = D("User")->getUserInfo($val['account']); $data[$key]['nickname'] = $user['nickname']; $data[$key]['head_img'] = $user['head_img']; $data[$key]['create_time'] = date("Y-m-d H:i:s",$data[$key]['create_time']); } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->我的收藏 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function usercollection($p=1) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $data = D("Game")->getMyCollectGame($this->suser->login_info('account'),$p); $this->assign("data",$data); $this->assign("page",$page); $this->display(); } /** * 个人中心->我的收藏 AJAX加载更多 * @return [type] [description] * @author 小纯洁 */ public function ajaxUserCollection(){ $page = I('post.p'); $row = C('LIST_ROWS'); $data = D("Game")->getMyCollectGame($this->suser->login_info('account'),$page); if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data,'p'=>$page)); } /** * 个人中心->我的收藏->设置收藏 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function set_collection(){ if(!$this->islogin()){$this->redirect('Mobile/User/login');} $game_id = $_REQUEST['game_id']; $account = $this->suser->login_info('account'); $status = $_REQUEST['status']; $result = D('Game')->collectGame($game_id,$account,$status); if($result != false){ $this->success("取消成功",U('User/usercollection')); }else{ $this->error("取消失败"); } } /** * 个人中心->我的邀请 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function userinvitation() { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $row = C('LIST_ROWS'); $map['invite_id'] = $this->suser->login_info('user_id'); $data = D('ShareRecord')->field("user_account,create_time,award_coin") ->where($map) ->order("create_time desc") ->group('user_id') ->page($page,$row) ->select(); foreach ($data as $key => $value) { $data[$key]['user_account'] = substr_replace($value['user_account'],'****',3,4); $data[$key]['create_time'] = date('Y-m-d',$value['create_time']); } $total_data = D('ShareRecord')->field("count(distinct user_id) as invite_num,sum(award_coin) as award_coin") ->where($map) ->group("invite_id") ->find(); $total_data['invite_num'] = empty($total_data['invite_num'])?0:$total_data['invite_num']; $total_data['award_coin'] = empty($total_data['award_coin'])?0:$total_data['award_coin']; $this->assign('data',$data); $this->assign('total_data',$total_data); $this->assign('page',$page); $this->display(); } /** * AJAX 我的评论加载更多 * @return [type] [description] */ public function ajaxInvitation() { $page = I('post.p'); $row = C('LIST_ROWS'); $map['invite_id'] = $this->suser->login_info('user_id'); $data = D('ShareRecord')->field("user_account,create_time,award_coin") ->where($map) ->order("create_time desc") ->page($page,$row) ->select(); foreach ($data as $key => $value) { $data[$key]['user_account'] = substr_replace($value['user_account'],'****',3,4); $data[$key]['create_time'] = date('Y-m-d',$value['create_time']); } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->我的积分 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function userintegral($type=1,$p=1) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $user_id = $this->suser->login_info('user_id'); $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 if($type == 1){ $map['pr.user_id'] = $user_id; $map['pr.type'] = $type; $data = D("PointRecord")->getUserAchieveRecord($map,"create_time desc",$page); }else{ $map['user_id'] = $user_id; $data = D("PointShopRecord")->getLists($map,"create_time desc",$page); } //$total = D('PointShopRecord')->getUserSpendPoint($user_id); $total = D('User')->getUserByAccount($this->suser->login_info('account'),'point'); $this->assign('data',$data); $this->assign('total',empty($total)?0:$total['point']); $this->display(); } /** * 个人中心->我的积分 AJAX 加载更多 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function ajaxUserIntegral($type=1){ $user_id = $this->suser->login_info('user_id'); $page = I('post.p'); $row = C('LIST_ROWS'); if($type == 1){ $map['pr.user_id'] = $user_id; $map['pr.type'] = $type; $data = D("PointRecord")->getUserAchieveRecord($map,"create_time desc",$page); foreach ($data as $key => $value) { $data[$key]['create_time'] = data('Y-m-d',$value['create_time']); } }else{ $map['user_id'] = $user_id; $data = D("PointShopRecord")->getLists($map,"create_time desc",$page); $data = $data['data']; foreach ($data as $key => $value) { $data[$key]['url'] = U('User/exchangerecorddetail',array('id'=>$value['id'])); $data[$key]['create_time'] = data('Y-m-d',$value['create_time']); } } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->我的积分->商品详情 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function exchangerecorddetail($id=0){ if(!$this->islogin()){$this->redirect('Mobile/User/login');} $map['sr.id'] = $id; $map['sr.user_id'] = $this->suser->login_info('user_id'); $data = D("PointShopRecord")->table("tab_point_shop_record as sr") ->field("ps.good_name,ps.good_type,ps.good_info,ps.good_usage,ps.cover,sr.number,sr.good_key,sr.user_name,sr.address,sr.phone") ->join("left join tab_point_shop ps on ps.id = sr.good_id") ->where($map) ->find(); $data['cover'] = get_img_url($data['cover']); $data['good_key'] = json_decode($data['good_key']); // var_dump($data['good_key']);die; $this->assign('data',$data); $this->display(); } /** * 个人中心->我的礼包 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function usergift($p=1) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $data = D("Giftbag")->getMyGiftRecord($this->suser->login_info('account'),$page); foreach ($data as $key => $value) { $data[$key]['end_time'] = empty($value['end_time'])?"永久":date('Y-m-d H:i:s',$value['end_time']); } $this->assign("data",$data); $this->assign("page",$page); $this->display(); } /** * 个人中心->我的礼包 AJAX加载更多 * @return [type] [description] * @author 小纯洁 */ public function ajaxUserGift(){ $page = I('post.p'); $row = C('LIST_ROWS'); $data = D("Giftbag")->getMyGiftRecord($this->suser->login_info('account'),$page); foreach ($data as $key => $value) { $data[$key]['start_time'] = date('Y-m-d',$value['start_time']); $data[$key]['end_time'] = date('Y-m-d',$value['end_time']); $data[$key]['url'] = U('Gift/detail',array('id'=>$value['gift_id'])); } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->兑换记录 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function exchangerecord($p=0) { if(!$this->islogin()){$this->redirect('Mobile/User/login');} $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $row = C('LIST_ROWS'); $map['user_id'] = $this->suser->login_info('user_id');//$user_id; $type = $_REQUEST['type']; if ($type == 2){ $map['good_type'] = ['in',[1,2]];//商品 $totalMap['good_type'] = ['in',[1,2]];//商品 }elseif ($type == 3) { $map['good_type'] = 3;//平台币 $totalMap['good_type'] = 3;//平台币 } $data = D("PointShopRecord") ->field("id,good_name,good_type,number,pay_amount,create_time") ->where($map) ->order('create_time desc') ->page($page, $row) ->select(); $totalMap['user_id'] = $this->suser->login_info('user_id'); $total = D("PointShopRecord")->where($totalMap)->sum("pay_amount"); $this->assign('total',empty($total)?0:$total); $this->assign('data',$data); $this->assign('page',$page); $this->display(); } /** * AJAX 兌換記錄加载更多 * @return [type] [description] */ public function ajaxExchangeRecord() { $page = I('post.p'); $row = C('LIST_ROWS'); $type = I('post.type'); $map['user_id'] = $this->suser->login_info('user_id');//$user_id; if ($type == 2){ $map['good_type'] = ['in',[1,2]];//商品 }elseif ($type == 3) { $map['good_type'] = 3;//平台币 } $data = D("PointShopRecord") ->field("id,good_name,good_type,number,pay_amount,create_time") ->where($map) ->order('create_time desc') ->page($page, $row) ->select(); foreach ($data as $key => $value) { $data[$key]['create_time'] = date('Y-m-d H:i:s',$value['create_time']); $data[$key]['durl'] = U('User/exchangerecorddetail',array('id'=>$value['id'])); } if (!empty($data) && is_array($data)) { $status = 1; } echo json_encode(array('status'=>$status,'page'=>$page,'lists'=>$data)); } /** * 个人中心->我的积分->获取方式 * @return [type] [description] * @author wyr <840186209@qq.com> */ public function userintegralguide(){ $model = new PointTypeModel(); $data = $model->getLists(['status'=>1]); foreach ($data['data'] as $key=>$val) { $result[$val['key']]['point'] = $val['point']; $result[$val['key']]['time_of_day'] = $val['time_of_day']; $result[$val['key']]['name'] = $val['name']; $result[$val['key']]['remake'] = $val['remake']; } $this->assign("data",$result); $this->display(); } public function share_register($id=0){ if(!empty($id)){ $data = D('Game')->find($id); $data['icon'] = get_cover($data['icon'],'path'); } $this->assign('data',$data); $this->display(); } /** * 绑定支付宝 */ public function alipay() { if(IS_POST) { $member = new MemberApi(); $user = D('User')->getLoginInfo(); if(is_array($user)) { $res = $member->save_alipay($user['user_id'],$_POST); $res['url'] = U('User/userset'); $this->ajaxReturn($res,'json'); } else { $this->ajaxReturn(['status'=>0,'msg'=>'请登录'],'json'); } } else { $this->assign('user',D('User')->getAlipay()); $this->display(); } } /** * 提现记录 * @param integer $p 当前页 * @author 鹿文学 */ public function withdraw_record($p=1) { $order = 'audit_time desc'; $lists = D('WithdrawGoldCoin')->lists($p,$map,'id,money,coin,status,order_number,if(audit_time>0,FROM_UNIXTIME(audit_time,"%Y-%m-%d %H:%i:%s"),"") as audit_time',$order); $this->assign('lists',$lists['lists']); $this->assign('page',$lists['current']); $this->assign('totalpage',$lists['total']); $this->display(); } /** * 提现记录 * @param integer $p 当前页 * @author 鹿文学 */ public function ajax_withdraw_record($p=1) { $order = 'audit_time desc'; $lists = D('WithdrawGoldCoin')->lists($p,$map,'id,money,coin,status,order_number,if(audit_time>0,FROM_UNIXTIME(audit_time,"%Y-%m-%d %H:%i:%s"),"") as audit_time',$order); $this->ajaxReturn($lists,'json'); } /** * 消费记录 * @param integer $p 当前页 * @author 鹿文学 */ public function useing_record($p=1) { $lists = D('User')->useing_record($p); foreach ($lists['lists'] as $key => $value) { $sort_data[$key] = $value['pay_time']; } array_multisort($sort_data,SORT_REGULAR,SORT_DESC,$lists['lists']); $this->assign('lists',$lists['lists']); $this->assign('page',$lists['current']); $this->assign('totalpage',$lists['total']); $this->display(); } /** * 消费记录 * @param integer $p 当前页 * @author 鹿文学 */ public function ajax_useing_record($p=1) { $lists = D('User')->useing_record($p); $this->ajaxReturn($lists,'json'); } }