You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1739 lines
56 KiB
PHP
1739 lines
56 KiB
PHP
<?php
|
|
namespace Mobile\Controller;
|
|
use Org\XiguSDK\Xigu;
|
|
use User\Api\SuserApi;
|
|
use Org\UcenterSDK\Ucservice;
|
|
use User\Api\MemberApi;
|
|
use Admin\Model\PointTypeModel;
|
|
|
|
class UserController extends BaseController {
|
|
private $suser;
|
|
|
|
public function __construct() {
|
|
parent::__construct();
|
|
$this->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' => 1,
|
|
'msg' => '登录成功!绑定失败',
|
|
);
|
|
}
|
|
} else {
|
|
if ($userData['promote_id'] == $promoteId) {
|
|
$data = array(
|
|
'status' => 2,
|
|
'msg' => '登录成功!绑定成功',
|
|
);
|
|
} else {
|
|
$data = array(
|
|
'status' => 0,
|
|
'msg' => '号码已绑定其他推广员',
|
|
);
|
|
}
|
|
}
|
|
} else {
|
|
$data = array(
|
|
'status' => 1,
|
|
'msg' => '登录成功!绑定失败',
|
|
);
|
|
}
|
|
} else {
|
|
$data = array(
|
|
'status' => 1,
|
|
'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 {
|
|
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 (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{
|
|
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'];
|
|
|
|
|
|
/**是否开启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;
|
|
}
|
|
|
|
$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');
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|