1340 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			1340 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| /**
 | ||
|  * tpshop
 | ||
|  * ============================================================================
 | ||
|  * * 版权所有 2015-2027 深圳搜豹网络科技有限公司,并保留所有权利。
 | ||
|  * 网站地址: http://www.tp-shop.cn
 | ||
|  * ----------------------------------------------------------------------------
 | ||
|  * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
 | ||
|  * 不允许对程序代码以任何形式任何目的的再发布。
 | ||
|  * 采用最新Thinkphp5助手函数特性实现单字母函数M D U等简写方式
 | ||
|  * ============================================================================
 | ||
|  * 2015-11-21
 | ||
|  */
 | ||
| namespace app\home\controller; 
 | ||
| use app\common\logic\Message;
 | ||
| use app\common\logic\OrderLogic;
 | ||
| use app\common\logic\UsersLogic;
 | ||
| use app\common\logic\CartLogic;
 | ||
| use app\common\model\GoodsCollect;
 | ||
| use app\common\model\GoodsVisit;
 | ||
| use app\common\model\UserAddress;
 | ||
| use app\common\model\UserMessage;
 | ||
| use app\common\util\TpshopException;
 | ||
| use think\Loader;
 | ||
| use think\Page;
 | ||
| use think\Session;
 | ||
| use think\Verify;
 | ||
| use think\Db;
 | ||
| class User extends Base{
 | ||
| 
 | ||
| 	public $user_id = 0;
 | ||
| 	public $user = array();
 | ||
| 	
 | ||
|     public function _initialize() {
 | ||
|         parent::_initialize();
 | ||
|         if(session('?user'))
 | ||
|         {
 | ||
|             $session_user = session('user');
 | ||
|             $select_user = Db::name('users')->where("user_id", $session_user['user_id'])->find();
 | ||
|             $oauth_users = Db::name('oauth_users')->where(['user_id'=>$session_user['user_id']])->find();
 | ||
|             empty($oauth_users) && $oauth_users = [];
 | ||
|             empty($select_user) && $select_user = []; // 有时报第一个错
 | ||
|             $user =  array_merge($select_user,$oauth_users);
 | ||
|             session('user',$user);  //覆盖session 中的 user
 | ||
|         	$this->user = $user;
 | ||
|         	$this->user_id = $user['user_id'];
 | ||
|         	$this->assign('user',$user); //存储用户信息
 | ||
|         	$this->assign('user_id',$this->user_id);
 | ||
|             //获取用户信息的数量
 | ||
|             $messageLogic = new Message();
 | ||
|             $user_message_count = $messageLogic->getUserMessageNoReadCount();
 | ||
|             $this->assign('user_message_count', $user_message_count);
 | ||
|         }
 | ||
|         $nologin = array(
 | ||
|                 'login','pop_login','do_login','logout','verify','set_pwd','finished',
 | ||
|                 'verifyHandle','reg','send_sms_reg_code','identity','check_validate_code',
 | ||
|             'forget_pwd', 'check_captcha', 'check_username', 'send_validate_code','bind_account','bind_guide','bind_reg',
 | ||
|         );
 | ||
|         if(!$this->user_id && !in_array(ACTION_NAME,$nologin)){
 | ||
|             $this->redirect('Home/User/login');
 | ||
|             exit;
 | ||
|         }
 | ||
| 
 | ||
|         //用户中心面包屑导航
 | ||
|         $navigate_user = navigate_user();
 | ||
|         $this->assign('navigate_user',$navigate_user);
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 用户中心首页
 | ||
|      */
 | ||
|     public function index(){
 | ||
|         $logic = new UsersLogic();
 | ||
|         $user = $logic->get_info($this->user_id);
 | ||
|         $user = $user['result'];
 | ||
|         $level = Db::name('user_level')->select();
 | ||
|         $level = convert_arr_key($level,'level_id');
 | ||
|         $coupon = $logic ->get_coupon($this->user_id,'','','',$p=2);
 | ||
|         $order = new \app\common\model\Order();
 | ||
|         $order_list = $order->where(['user_id'=>$user[user_id],'prom_type'=>['<',5]])->whereOr(['prom_type'=>7])->limit(1)->order('order_id desc')->select();
 | ||
|         $this->assign('coupon',$coupon['result']);
 | ||
|         $this->assign('level',$level);
 | ||
|         $this->assign('user',$user);
 | ||
|         $this->assign('order_list',$order_list);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
|     public function logout(){
 | ||
|     	setcookie('uname','',time()-3600,'/');
 | ||
|     	setcookie('cn','',time()-3600,'/');
 | ||
|     	setcookie('user_id','',time()-3600,'/');
 | ||
|         setcookie('PHPSESSID','',time()-3600,'/');
 | ||
|         session_unset();
 | ||
|         session_destroy();
 | ||
|         //$this->success("退出成功",U('Home/Index/index'));
 | ||
|         $this->redirect('Home/Index/index');
 | ||
|         exit;
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 账户资金
 | ||
|      */
 | ||
|     public function account(){
 | ||
|         $user = session('user');
 | ||
|         $type = I('type');
 | ||
|         $order_sn = I('order_sn');
 | ||
|         $logic = new UsersLogic();
 | ||
|         $data = $logic->get_account_log($this->user_id,$type,$order_sn);
 | ||
|         $account_log = $data['result'];
 | ||
|         $this->assign('user',$user);
 | ||
|         $this->assign('account_log',$account_log);
 | ||
|         $this->assign('page',$data['show']);
 | ||
|         $this->assign('active','account');
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|     /*
 | ||
|      * 优惠券列表
 | ||
|      */
 | ||
|     public function coupon(){
 | ||
|         $logic = new UsersLogic();
 | ||
|         $data = $logic->get_coupon($this->user_id,I('type'));
 | ||
|         foreach($data['result'] as $k =>$v){
 | ||
|             $user_type = $v['use_type'];
 | ||
|             $data['result'][$k]['use_scope'] = C('COUPON_USER_TYPE')["$user_type"];
 | ||
|             if($user_type==1){ //指定商品
 | ||
|                 $data['result'][$k]['goods_id'] = M('goods_coupon')->field('goods_id')->where(['coupon_id'=>$v['cid']])->getField('goods_id');
 | ||
|             }
 | ||
|             if($user_type==2){ //指定分类
 | ||
|                 $data['result'][$k]['category_id'] = Db::name('goods_coupon')->where(['coupon_id'=>$v['cid']])->getField('goods_category_id');
 | ||
|             }
 | ||
|         }
 | ||
|         $coupon_list = $data['result'];
 | ||
|         $this->assign('coupon_list',$coupon_list);
 | ||
|         $this->assign('page',$data['show']);
 | ||
|         $this->assign('active','coupon');
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|     /**
 | ||
|      *  登录
 | ||
|      */
 | ||
|     public function login(){
 | ||
|         if($this->user_id > 0){
 | ||
|             $this->redirect('Home/User/index');
 | ||
|         }
 | ||
|         $redirect_url = Session::get('redirect_url');
 | ||
|         $referurl = $redirect_url ? $redirect_url : U("Home/User/index");
 | ||
|         $this->assign('referurl',$referurl);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     public function pop_login(){
 | ||
|     	if($this->user_id > 0){
 | ||
|             $this->redirect('Home/User/index');
 | ||
|     	}
 | ||
|         $referurl = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : U("Home/User/index");
 | ||
|         $this->assign('referurl',$referurl);
 | ||
|     	return $this->fetch();
 | ||
|     }
 | ||
|     
 | ||
|     public function do_login(){
 | ||
|         $username = trim(I('post.username'));
 | ||
|         $password = trim(I('post.password'));
 | ||
|     	$verify_code = I('post.verify_code');
 | ||
|      
 | ||
|         $verify = new Verify();
 | ||
|         if (!$verify->check($verify_code,'user_login'))
 | ||
|         {
 | ||
|              $res = array('status'=>0,'msg'=>'验证码错误');
 | ||
|              exit(json_encode($res));
 | ||
|         }
 | ||
|     	         
 | ||
|     	$logic = new UsersLogic();
 | ||
|     	$res = $logic->login($username,$password);
 | ||
| 
 | ||
|     	if($res['status'] == 1){
 | ||
|     		$res['url'] =  htmlspecialchars_decode(I('post.referurl'));
 | ||
|     		session('user',$res['result']);
 | ||
|     		setcookie('user_id',$res['result']['user_id'],null,'/');
 | ||
|     		setcookie('is_distribut',$res['result']['is_distribut'],null,'/');
 | ||
|     		$nickname = empty($res['result']['nickname']) ? $username : $res['result']['nickname'];
 | ||
|             setcookie('uname',urlencode($nickname),null,'/');
 | ||
|             setcookie('cn',0,time()-3600,'/');
 | ||
|     		$cartLogic = new CartLogic();
 | ||
|             $cartLogic->setUserId($res['result']['user_id']);
 | ||
|             $cartLogic->doUserLoginHandle();// 用户登录后 需要对购物车 一些操作
 | ||
|             $orderLogic = new OrderLogic();
 | ||
|             $orderLogic->setUserId($res['result']['user_id']); //登录后将超时未支付订单给取消掉
 | ||
|             $orderLogic->abolishOrder();
 | ||
|     	}
 | ||
|     	exit(json_encode($res));
 | ||
|     }
 | ||
|     /**
 | ||
|      *  注册
 | ||
|      */
 | ||
|     public function reg(){
 | ||
|     	if($this->user_id > 0){
 | ||
|             $this->redirect('Home/User/index');
 | ||
|         }
 | ||
|         $reg_sms_enable = tpCache('sms.regis_sms_enable');
 | ||
|         $reg_smtp_enable = tpCache('smtp.regis_smtp_enable');
 | ||
|         if(IS_POST){
 | ||
|             $logic = new UsersLogic();
 | ||
|             //验证码检验
 | ||
| //            $this->verifyHandle('user_reg');
 | ||
|             $username = I('post.username','');
 | ||
|             $password = I('post.password','');
 | ||
|             $password2 = I('post.password2','');
 | ||
|             $code = I('post.code','');
 | ||
|             $scene = I('post.scene', 1);
 | ||
|             $session_id = session_id();
 | ||
|             if(check_mobile($username)){
 | ||
|                 if($reg_sms_enable){   //是否开启注册验证码机制
 | ||
|                     //手机功能没关闭
 | ||
|                     $check_code = $logic->check_validate_code($code, $username, 'phone', $session_id, $scene);
 | ||
|                     if($check_code['status'] != 1){
 | ||
|                         $this->ajaxReturn($check_code);
 | ||
|                     }
 | ||
|                 }else{
 | ||
|                     if(!$this->verifyHandle('user_reg')){
 | ||
|                         $this->ajaxReturn(['status'=>-1,'msg'=>'图像验证码错误']);
 | ||
|                     };
 | ||
|                 }
 | ||
|             }
 | ||
|             if(check_email($username)){
 | ||
|                 if($reg_smtp_enable){        //是否开启注册邮箱验证码机制
 | ||
|                     //邮件功能未关闭
 | ||
|                     $check_code = $logic->check_validate_code($code, $username);
 | ||
|                     if($check_code['status'] != 1){
 | ||
|                         $this->ajaxReturn($check_code);
 | ||
|                     }
 | ||
|                 }else{
 | ||
|                     if(!$this->verifyHandle('user_reg')){
 | ||
|                         $this->ajaxReturn(['status'=>-1,'msg'=>'图像验证码错误']);
 | ||
|                     };
 | ||
|                 }
 | ||
|             }
 | ||
|             $invite = I('invite');
 | ||
|             if(!empty($invite)){
 | ||
|             	$invite = get_user_info($invite,2);//根据手机号查找邀请人
 | ||
|             }
 | ||
|             $data = $logic->reg($username,$password,$password2,0,$invite);
 | ||
|             if($data['status'] != 1){
 | ||
|                 $this->ajaxReturn($data);
 | ||
|             }
 | ||
|             session('user',$data['result']);
 | ||
|     		setcookie('user_id',$data['result']['user_id'],null,'/');
 | ||
|     		setcookie('is_distribut',$data['result']['is_distribut'],null,'/');
 | ||
|             $nickname = empty($data['result']['nickname']) ? $username : $data['result']['nickname'];
 | ||
|             setcookie('uname',$nickname,null,'/');
 | ||
|             $cartLogic = new CartLogic();
 | ||
|             $cartLogic->setUserId($data['result']['user_id']);
 | ||
|             $cartLogic->doUserLoginHandle();// 用户登录后 需要对购物车 一些操作
 | ||
|             $this->ajaxReturn($data);
 | ||
|             exit;
 | ||
|         }
 | ||
|         $this->assign('regis_sms_enable',tpCache('sms.regis_sms_enable')); // 注册启用短信:
 | ||
|         $this->assign('regis_smtp_enable',tpCache('smtp.regis_smtp_enable')); // 注册启用邮箱:
 | ||
|         $sms_time_out = tpCache('sms.sms_time_out')>0 ? tpCache('sms.sms_time_out') : 120;
 | ||
|         $this->assign('sms_time_out', $sms_time_out); // 手机短信超时时间
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 用户地址列表
 | ||
|      */
 | ||
|     public function address_list(){
 | ||
|         $address_lists = get_user_address_list($this->user_id);
 | ||
|         $region_list = get_region_list();
 | ||
|         $this->assign('region_list',$region_list);
 | ||
|         $this->assign('lists',$address_lists);
 | ||
|         $this->assign('active','address_list');
 | ||
| 
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     public function address()
 | ||
|     {
 | ||
|         $address_id = input('address_id/d',0);
 | ||
|         $userAddress = UserAddress::get(['address_id'=>$address_id,'user_id'=> $this->user_id]);
 | ||
|         if(empty($userAddress)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '参数错误']);
 | ||
|         }
 | ||
|         $city_list = Db::name('region')->where('parent_id',$userAddress['province'])->select();
 | ||
|         $district_list = Db::name('region')->where('parent_id',$userAddress['city'])->select();
 | ||
|         $twon_list = Db::name('region')->where('parent_id',$userAddress['district'])->select();
 | ||
|         $this->ajaxReturn(['status' => 1, 'msg' => '获取成功','result'=>['user_address'=>$userAddress,'city_list'=>$city_list,'district_list'=>$district_list,'twon_list'=>$twon_list]]);
 | ||
|     }
 | ||
|     /**
 | ||
|      * 设置默认收货地址 与多商城保持一致
 | ||
|      */
 | ||
|     public function setAddressDefault()
 | ||
|     {
 | ||
|         $id = input('id/d');
 | ||
|         Db::name('user_address')->where(['user_id'=>$this->user_id])->update(['is_default' => 0]);
 | ||
|         $row = Db::name('user_address')->where(array('user_id' => $this->user_id, 'address_id' => $id))->update(array('is_default' => 1));
 | ||
|         if ($row !== false){
 | ||
|             $this->ajaxReturn(['status'=>1,'msg'=>'设置成功','result'=>'']);
 | ||
|         }else{
 | ||
|             $this->ajaxReturn(['status'=>0,'msg'=>'设置失败','result'=>$row]);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 保存地址
 | ||
|      */
 | ||
|     public function addressSave()
 | ||
|     {
 | ||
|         $address_id = input('address_id/d',0);
 | ||
|         $data = input('post.');
 | ||
|         $userAddressValidate = Loader::validate('UserAddress');
 | ||
|         if (!$userAddressValidate->batch()->check($data)) {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '操作失败', 'result' => $userAddressValidate->getError()]);
 | ||
|         }
 | ||
|         if (!empty($address_id)) {
 | ||
|             //编辑
 | ||
|             $userAddress = UserAddress::get(['address_id'=>$address_id,'user_id'=> $this->user_id]);
 | ||
|             if(empty($userAddress)){
 | ||
|                 $this->ajaxReturn(['status' => 0, 'msg' => '参数错误']);
 | ||
|             }
 | ||
|         } else {
 | ||
|             //新增
 | ||
|             $userAddress = new UserAddress();
 | ||
|             $user_address_count = Db::name('user_address')->where("user_id", $this->user_id)->count();
 | ||
|             if ($user_address_count >= 20) {
 | ||
|                 $this->ajaxReturn(['status' => 0, 'msg' => '最多只能添加20个收货地址']);
 | ||
|             }
 | ||
|             $data['user_id'] = $this->user_id;
 | ||
|         }
 | ||
|         $userAddress->data($data, true);
 | ||
|         $userAddress['longitude'] = true;
 | ||
|         $userAddress['latitude'] = true;
 | ||
|         $row = $userAddress->allowField(true)->save();
 | ||
|         if ($row !== false) {
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '操作成功']);
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '操作失败']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 设置默认地址
 | ||
|      */
 | ||
|     public function addressSetDefault()
 | ||
|     {
 | ||
|         $address_id = input('address_id/d', 0);
 | ||
|         $userAddress = UserAddress::get(['address_id'=>$address_id,'user_id'=> $this->user_id]);
 | ||
|         if(empty($userAddress)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '参数错误']);
 | ||
|         }
 | ||
|         Db::name('user_address')->where('user_id',$this->user_id)->save(['is_default'=>0]);
 | ||
|         $row = $userAddress->save(['is_default'=>1]);
 | ||
|         if ($row !== false) {
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '操作成功']);
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '操作失败']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 地址删除
 | ||
|      */
 | ||
|     public function addressDelete()
 | ||
|     {
 | ||
|         $address_id = input('address_id/d', 0);
 | ||
|         $deleteAddress = Db::name('user_address')->where(['address_id'=>$address_id,'user_id'=> $this->user_id])->find();
 | ||
|         if(empty($deleteAddress)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '参数错误']);
 | ||
|         }
 | ||
|         // 如果删除的是默认收货地址 则要把第一个地址设置为默认收货地址
 | ||
|         if($deleteAddress['is_default'] == 1)
 | ||
|         {
 | ||
|             $addressDefault = UserAddress::get(['user_id'=> $this->user_id]);
 | ||
|             if($addressDefault){
 | ||
|                 $addressDefault->save(['is_default'=>1]);
 | ||
|             }
 | ||
|         }
 | ||
|         $row = Db::name('user_address')->where('address_id',$deleteAddress['address_id'])->delete();
 | ||
|         if ($row !== false) {
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '操作成功']);
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '操作失败']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
|     /*
 | ||
|      * 个人信息
 | ||
|      */
 | ||
|     public function info(){
 | ||
|         $userLogic = new UsersLogic();
 | ||
|         $user_info = $userLogic->get_info($this->user_id); // 获取用户信息
 | ||
|         $user_info = $user_info['result'];
 | ||
|         if(IS_POST){
 | ||
|             I('post.nickname') ? $post['nickname'] = I('post.nickname') : false; //昵称
 | ||
|             I('post.qq') ? $post['qq'] = I('post.qq') : false;  //QQ号码
 | ||
|             I('post.head_pic') ? $post['head_pic'] = I('post.head_pic') : false; //头像地址
 | ||
|             I('post.sex') ? $post['sex'] = I('post.sex') : $post['sex'] = 0;  // 性别
 | ||
|             I('post.birthday') ? $post['birthday'] = strtotime(I('post.birthday')) : false;  // 生日
 | ||
|             I('post.province') ? $post['province'] = I('post.province') : false;  //省份
 | ||
|             I('post.city') ? $post['city'] = I('post.city') : false;  // 城市
 | ||
|             I('post.district') ? $post['district'] = I('post.district') : false;  //地区
 | ||
|             if(!$userLogic->update_info($this->user_id,$post))
 | ||
|                 $this->error("保存失败");
 | ||
|             setcookie('uname',urlencode($post['nickname']),null,'/');
 | ||
|             $this->success("操作成功");
 | ||
|             exit;
 | ||
|         }
 | ||
|         //  获取省份
 | ||
|         $province = Db::name('region')->where(array('parent_id'=>0,'level'=>1))->select();
 | ||
|         //  获取订单城市
 | ||
|         $city =  Db::name('region')->where(array('parent_id'=>$user_info['province'],'level'=>2))->select();
 | ||
|         //获取订单地区
 | ||
|         $area =  Db::name('region')->where(array('parent_id'=>$user_info['city'],'level'=>3))->select();
 | ||
| 
 | ||
|         $this->assign('province',$province);
 | ||
|         $this->assign('city',$city);
 | ||
|         $this->assign('area',$area);
 | ||
|         $this->assign('user',$user_info);
 | ||
|         $this->assign('sex',C('SEX'));
 | ||
|         $this->assign('active','info');
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 邮箱验证
 | ||
|      */
 | ||
|     public function email_validate(){
 | ||
|         $userLogic = new UsersLogic();
 | ||
|         $user_info = $userLogic->get_info($this->user_id); // 获取用户信息
 | ||
|         $user_info = $user_info['result'];
 | ||
|         $step = I('get.step',1);
 | ||
|         if(IS_POST){
 | ||
|             $email = I('post.email');
 | ||
|             $old_email = I('post.old_email',''); //旧邮箱
 | ||
|             $code = I('post.code');
 | ||
|             $info = session('validate_code');
 | ||
|             if(!$info)
 | ||
|                 $this->error('非法操作');
 | ||
|             if($info['time']<time()){
 | ||
|             	session('validate_code',null);
 | ||
|             	$this->error('验证超时,请重新验证');
 | ||
|             }
 | ||
|             //检查原邮箱是否正确
 | ||
|             if($user_info['email_validated'] == 1 && $old_email != $user_info['email'])
 | ||
|                 $this->error('原邮箱匹配错误');
 | ||
|             //验证邮箱和验证码
 | ||
|             if($info['sender'] == $email && $info['code'] == $code){
 | ||
|                 session('validate_code',null);
 | ||
|                 if(!$userLogic->update_email_mobile($email,$this->user_id))
 | ||
|                     $this->error('邮箱已存在');
 | ||
|                 $this->success('绑定成功',U('Home/User/index'));
 | ||
|                 exit;
 | ||
|             }
 | ||
|             $this->error('邮箱验证码不匹配');
 | ||
|         }
 | ||
|         $this->assign('user_info',$user_info);
 | ||
|         $this->assign('step',$step);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
|     /**
 | ||
|      * 手机验证
 | ||
|      * @return mixed
 | ||
|      */
 | ||
|     public function mobile_validate()
 | ||
|     {
 | ||
|         $user_info = $this->user;
 | ||
|         $config = tpCache('sms');
 | ||
|         $sms_time_out = $config['sms_time_out'];
 | ||
|         $this->assign('time', $sms_time_out);
 | ||
|         if (IS_POST) {
 | ||
|             $old_mobile = I('post.old_mobile');
 | ||
|             $code = I('post.code');
 | ||
|             $scene = I('post.scene', 6);
 | ||
|             $session_id = I('unique_id', session_id());
 | ||
| 
 | ||
|             $logic = new UsersLogic();
 | ||
|             $res = $logic->check_validate_code($code, $old_mobile, 'phone', $session_id, $scene);
 | ||
| 
 | ||
|             if (!$res && $res['status'] != 1) $this->error($res['msg']);
 | ||
| 
 | ||
|             //检查原手机是否正确
 | ||
|             if ($user_info['mobile_validated'] == 1 && $old_mobile != $user_info['mobile'])
 | ||
|                 $this->error('原手机号码错误');
 | ||
|             //验证手机和验证码
 | ||
|             if ($res['status'] == 1) {
 | ||
|                 return $this->fetch('set_mobile');
 | ||
|             } else {
 | ||
|                 $this->error($res['msg']);
 | ||
|             }
 | ||
|         }
 | ||
|         $this->assign('user_info', $user_info);
 | ||
|         if (empty($user_info['mobile'])){
 | ||
|             return $this->fetch('set_mobile');
 | ||
|         }
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 设置新手机
 | ||
|      * @return mixed
 | ||
|      */
 | ||
|     public function set_mobile()
 | ||
|     {
 | ||
|         $userLogic = new UsersLogic();
 | ||
|         $mobile = I('post.mobile');
 | ||
|         $code = I('post.code');
 | ||
|         $scene = I('post.scene', 6);
 | ||
|         $session_id = I('unique_id', session_id());
 | ||
|         $logic = new UsersLogic();
 | ||
|         $res = $logic->check_validate_code($code, $mobile, 'phone', $session_id, $scene);
 | ||
|         //验证手机和验证码
 | ||
|         if ($res['status'] == 1) {
 | ||
|             //验证有效期
 | ||
|             if (!$userLogic->update_email_mobile($mobile, $this->user_id, 2)){
 | ||
|                 $this->ajaxReturn(['status'=>-1,'msg'=>'手机已存在']);
 | ||
|             }else{
 | ||
|                 $this->ajaxReturn(['status'=>1,'msg'=>'修改成功']);
 | ||
|             }
 | ||
|             exit;
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status'=>-1,'msg'=>$res['msg']]);
 | ||
|         }
 | ||
| 
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      *商品收藏
 | ||
|      */
 | ||
|     public function goods_collect(){
 | ||
|         $userLogic = new UsersLogic();
 | ||
|         $data = $userLogic->get_goods_collect($this->user_id);
 | ||
|         $this->assign('page',$data['show']);// 赋值分页输出
 | ||
|         $this->assign('lists',$data['result']);
 | ||
|         $this->assign('active','goods_collect');
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 删除一个收藏商品
 | ||
|      */
 | ||
|     public function delGoodsCollect(){
 | ||
|         $ids = trim(I('get.ids',''),',');
 | ||
|         if(!$ids)$this->ajaxReturn(['status'=>-1,'msg'=>"请选择商品"]);
 | ||
|         $row = Db::name('goods_collect')->where(['user_id'=>$this->user_id,'collect_id'=>['in',$ids]])->delete();
 | ||
|         if(!$row)$this->ajaxReturn(['status'=>-1,'msg'=>'删除失败']);
 | ||
|         $this->ajaxReturn(['status'=>1,'msg'=>'删除成功','url'=>U('User/goods_collect')]);
 | ||
|     }
 | ||
| 
 | ||
|     /*
 | ||
|      * 密码修改
 | ||
|      */
 | ||
|     public function password(){
 | ||
|         //检查是否第三方登录用户
 | ||
|         $logic = new UsersLogic();
 | ||
|         $data = $logic->get_info($this->user_id);
 | ||
|         $user = $data['result'];
 | ||
|         if($user['mobile'] == ''&& $user['email'] == '')
 | ||
|             $this->error('请先绑定手机或邮箱',U('Home/User/info'));
 | ||
|         if(IS_POST){
 | ||
|             $userLogic = new UsersLogic();
 | ||
|             $data = $userLogic->password($this->user_id,I('post.old_password'),I('post.new_password'),I('post.confirm_password')); // 获取用户信息
 | ||
|             if($data['status'] == -1)
 | ||
|                 $this->error($data['msg']);
 | ||
|             $this->success($data['msg']);
 | ||
|             exit;
 | ||
|         }
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     public function forget_pwd()
 | ||
|     {
 | ||
|         if ($this->user_id > 0) {
 | ||
|             header("Location: " . U('Home/User/Index'));
 | ||
|         }
 | ||
|         if (IS_POST) {
 | ||
|             $username = I('username');
 | ||
|             if (!empty($username)) {
 | ||
|                 $field = 'mobile';
 | ||
|                 if (check_email($username)) {
 | ||
|                     $field = 'email';
 | ||
|                 }
 | ||
|                 $user = M('users')->where("email", $username)->whereOr('mobile', $username)->find();
 | ||
|                 
 | ||
|                 if ($user) {
 | ||
|                     session('find_password', array('user_id' => $user['user_id'], 'username' => $username,
 | ||
|                         'email' => $user['email'], 'mobile' => $user['mobile'], 'type' => $field));
 | ||
|                     header("Location: " . U('User/identity'));
 | ||
|                     exit;
 | ||
|                 } else {
 | ||
|                    echo "用户名不存在,请检查";
 | ||
|                     $this->error("用户名不存在,请检查");
 | ||
|                 }
 | ||
|             }
 | ||
|         }
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|     
 | ||
|     public function set_pwd(){
 | ||
|     	if($this->user_id > 0){
 | ||
|             $this->redirect('Home/User/Index');
 | ||
|     	}
 | ||
|     	$check = session('validate_code');
 | ||
|     	$logic = new UsersLogic();
 | ||
|     	if(empty($check)){
 | ||
|             $this->redirect('Home/User/forget_pwd');
 | ||
|     	}elseif($check['is_check']==0){
 | ||
|     		$this->error('验证码还未验证通过',U('Home/User/forget_pwd'));
 | ||
|     	}    	
 | ||
|     	if(IS_POST){
 | ||
|     		$password = I('post.password');
 | ||
|     		$password2 = I('post.password2');
 | ||
| //    		if($password2 != $password){
 | ||
| //    			$this->error('两次密码不一致',U('Home/User/forget_pwd'));
 | ||
| //    		}
 | ||
|             $data['password'] =  I('post.password');
 | ||
|             $data['password2'] =  I('post.password2');
 | ||
|             $UserRegvalidate = Loader::validate('User');
 | ||
|             if(!$UserRegvalidate->scene('set_pwd')->check($data)){
 | ||
|                 $this->error($UserRegvalidate->getError(),U('User/forget_pwd'));
 | ||
|             }
 | ||
|     		if($check['is_check']==1){
 | ||
|     			//$user = get_user_info($check['sender'],1);
 | ||
|                 $user = Db::name('users')->where("mobile|email", '=', $check['sender'])->find();
 | ||
|     			Db::name('users')->where("user_id", $user['user_id'])->save(array('password'=>encrypt($password)));
 | ||
|     			session('validate_code',null);
 | ||
|                 $this->redirect('Home/User/finished');
 | ||
|     		}else{
 | ||
|     			$this->error('验证码还未验证通过',U('Home/User/forget_pwd'));
 | ||
|     		}
 | ||
|     	}
 | ||
|     	return $this->fetch();
 | ||
|     }
 | ||
|     
 | ||
|     public function finished(){
 | ||
|     	if($this->user_id > 0){
 | ||
|             $this->redirect('Home/User/Index');
 | ||
|     	}
 | ||
|     	return $this->fetch();
 | ||
|     }   
 | ||
|     /**
 | ||
|      * 绑定已有账号
 | ||
|      * @return \think\mixed
 | ||
|      */
 | ||
|     public function bind_account()
 | ||
|     {
 | ||
|         $mobile = input('mobile/s');
 | ||
|         $verify_code = input('verify_code/s');
 | ||
|         //发送短信验证码
 | ||
|         $logic = new UsersLogic();
 | ||
|         $check_code = $logic->check_validate_code($verify_code, $mobile, 'phone', session_id(), 1);
 | ||
|         if($check_code['status'] != 1){
 | ||
|             $this->ajaxReturn(['status'=>0,'msg'=>$check_code['msg'],'result'=>'']);
 | ||
|         }
 | ||
|         if(empty($mobile) || !check_mobile($mobile)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '手机格式错误']);
 | ||
|         }
 | ||
|         $users = Db::name('users')->where('mobile',$mobile)->find();
 | ||
|         if (empty($users)) {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '账号不存在']);
 | ||
|         }
 | ||
|         $user = new \app\common\logic\User();
 | ||
|         $user->setUserById($users['user_id']);
 | ||
|         $cartLogic = new CartLogic();
 | ||
|         try{
 | ||
|             $user->checkOauthBind();
 | ||
|             $user->oauthBind();
 | ||
|             $user->doLeader();
 | ||
|             $user->refreshCookie();
 | ||
|             $cartLogic->setUserId($users['user_id']);
 | ||
|             $cartLogic->doUserLoginHandle();
 | ||
|             $orderLogic = new OrderLogic();//登录后将超时未支付订单给取消掉
 | ||
|             $orderLogic->setUserId($users['user_id']);
 | ||
|             $orderLogic->abolishOrder();
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '绑定成功']);
 | ||
|         }catch (TpshopException $t){
 | ||
|             $error = $t->getErrorArr();
 | ||
|             $this->ajaxReturn($error);
 | ||
|         }
 | ||
|     }
 | ||
|     
 | ||
|     public function bind_guide(){
 | ||
|         
 | ||
|         $data = session('third_oauth');
 | ||
|         $this->assign("nickname", $data['nickname']);
 | ||
|         $this->assign("oauth", $data['oauth']);
 | ||
|         $this->assign("head_pic", $data['head_pic']);
 | ||
|         $this->assign('store_name',tpCache('shop_info.store_name'));
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|     
 | ||
|     /**
 | ||
|      * 先注册再绑定账号
 | ||
|      * @return \think\mixed
 | ||
|      */
 | ||
|     public function bind_reg()
 | ||
|     {
 | ||
|         $mobile = input('mobile/s');
 | ||
|         $verify_code = input('verify_code/s');
 | ||
|         $password = input('password/s');
 | ||
|         $nickname = input('nickname/s', '');
 | ||
|         if(empty($mobile) || !check_mobile($mobile)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '手机格式错误']);
 | ||
|         }
 | ||
|         if(empty($password)){
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '请输入密码']);
 | ||
|         }
 | ||
|         $logic = new UsersLogic();
 | ||
|         $check_code = $logic->check_validate_code($verify_code, $mobile, 'phone', session_id(), 1);
 | ||
|         if($check_code['status'] != 1){
 | ||
|             $this->ajaxReturn(['status'=>0,'msg'=>$check_code['msg'],'result'=>'']);
 | ||
|         }
 | ||
|         $thirdUser = session('third_oauth');
 | ||
|         $data = $logic->reg($mobile, $password, $password, 0, [], $nickname, $thirdUser['head_pic']);
 | ||
|         if ($data['status'] != 1) {
 | ||
|             $this->ajaxReturn(['status'=>0,'msg'=>$data['msg'],'result'=>'']);
 | ||
|         }
 | ||
|         $user = new \app\common\logic\User();
 | ||
|         $user->setUserById($data['result']['user_id']);
 | ||
|         try{
 | ||
|             $user->checkOauthBind();
 | ||
|             $user->oauthBind();
 | ||
|             $user->refreshCookie();
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '绑定成功']);
 | ||
|         }catch (TpshopException $t){
 | ||
|             $error = $t->getErrorArr();
 | ||
|             $this->ajaxReturn($error);
 | ||
|         }
 | ||
|     }
 | ||
|     
 | ||
|     public function bind_auth()
 | ||
|     {
 | ||
|  
 | ||
|         $list = Db::name('plugin')->cache(true)->where(array('type' => 'login', 'status' => 1))->select();
 | ||
|         if ($list) {
 | ||
|             foreach ($list as $val) {
 | ||
|                 $val['is_bind'] = 0;
 | ||
|                 
 | ||
|                 $thridUser = M('OauthUsers')->where(array('user_id'=>$this->user['user_id'] , 'oauth'=>$val['code']))->find();
 | ||
|                  if ($thridUser) {
 | ||
|                     $val['is_bind'] = 1;
 | ||
|                 }
 | ||
|                 $val['bind_url'] = U('LoginApi/login', array('oauth' => $val['code']));
 | ||
|                 $val['bind_remove'] = U('User/bind_remove', array('oauth' => $val['code']));;
 | ||
|                 $val['config_value'] = unserialize($val['config_value']);
 | ||
|                 $lists[] = $val;
 | ||
|             }
 | ||
|         }
 | ||
|         $this->assign('lists', $lists);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     public function bind_remove()
 | ||
|     {
 | ||
|         $oauth = I('oauth'); 
 | ||
|         $row = Db::name('oauth_users')->where(array('user_id' => $this->user_id , 'oauth'=>$oauth))->delete();
 | ||
|         if ($row) {
 | ||
|             $this->success('解除绑定成功', U('Home/User/bind_auth'));
 | ||
|         } else {
 | ||
|             $this->error('解除绑定失败', U('Home/User/bind_auth'));
 | ||
|         }
 | ||
|         
 | ||
|     }
 | ||
|     public function check_captcha(){
 | ||
|     	$verify = new Verify();
 | ||
|     	$type = I('post.type','user_login');
 | ||
|     	if (!$verify->check(I('post.verify_code'), $type)) {
 | ||
|     		exit(json_encode(0));
 | ||
|     	}else{
 | ||
|     		exit(json_encode(1));
 | ||
|     	}
 | ||
|     }
 | ||
|     
 | ||
|     public function check_username(){
 | ||
|     	$username = I('post.username');
 | ||
|     	if(!empty($username)){
 | ||
|     		$count = Db::name('users')->where("email", $username)->whereOr('mobile', $username)->count();
 | ||
|     		exit(json_encode(intval($count)));
 | ||
|     	}else{
 | ||
|     		exit(json_encode(0));
 | ||
|     	}  	
 | ||
|     }
 | ||
| 
 | ||
|     public function identity()
 | ||
|     {
 | ||
|         if ($this->user_id > 0) {
 | ||
|             header("Location: " . U('Home/User/Index'));
 | ||
|         }
 | ||
|         $user = session('find_password');
 | ||
|         if (empty($user)) {
 | ||
|             $this->error("请先验证用户名", U('User/forget_pwd'));
 | ||
|         }
 | ||
|         $this->assign('userinfo', $user);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|       
 | ||
|     /**
 | ||
|      * 验证码验证
 | ||
|      * $id 验证码标示
 | ||
|      */
 | ||
|     private function verifyHandle($id)
 | ||
|     {
 | ||
|         $verify = new Verify();
 | ||
|         $result = $verify->check(I('post.verify_code'), $id ? $id : 'user_login');
 | ||
|         if (!$result) {
 | ||
|             return false;
 | ||
|         }else{
 | ||
|             return true;
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 验证码获取
 | ||
|      */
 | ||
|     public function verify()
 | ||
|     {
 | ||
|         //验证码类型
 | ||
|         $type = I('get.type') ? I('get.type') : 'user_login';
 | ||
|         $config = array(
 | ||
|             'fontSize' => 40,
 | ||
|             'length' => 4,
 | ||
|             'useCurve' => false,
 | ||
|             'useNoise' => false,
 | ||
|         );
 | ||
|         $Verify = new Verify($config);
 | ||
|         $Verify->entry($type);
 | ||
| 		exit();
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 安全设置
 | ||
|      */
 | ||
|     public function safety_settings()
 | ||
|     {
 | ||
|         $userLogic = new UsersLogic();
 | ||
|         $user_info = $userLogic->get_info($this->user_id); // 获取用户信息
 | ||
|         $user_info = $user_info['result'];        
 | ||
|         $this->assign('user',$user_info);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     //添加、编辑提现账号
 | ||
|     public function add_card(){
 | ||
|         $user_id=$this->user_id;
 | ||
|         $data=I('post.');
 | ||
|         //dump($data);exit();
 | ||
| 
 | ||
|         if($data['type']==0){
 | ||
|             $info['cash_alipay']=$data['card'];
 | ||
|         }
 | ||
|         if($data['type']==1){
 | ||
|             $info['cash_weixinpay']=$data['card'];
 | ||
|         }
 | ||
|         $info['realname']=$data['cash_name'];
 | ||
|         $info['user_id']=$user_id;
 | ||
|         $res=Db::name('user_extend')->where('user_id='.$user_id)->count();
 | ||
|         if($res){
 | ||
|             $res2=Db::name('user_extend')->where('user_id='.$user_id)->save($info);
 | ||
|         }else{
 | ||
|             if (!isset($info['cash_unionpay'])) {
 | ||
|                 # code...cash_unionpay 需要默认值
 | ||
|                 $info['cash_unionpay'] = '';
 | ||
|             }
 | ||
|             $res2=Db::name('user_extend')->add($info);
 | ||
|         }
 | ||
|         $this->ajaxReturn(['status'=>1,'msg'=>'操作成功']);
 | ||
|     }
 | ||
|     
 | ||
|     /**
 | ||
|      * 申请提现记录
 | ||
|      */
 | ||
|     public function withdrawals(){
 | ||
|         $cash_open=tpCache('cash.cash_open');
 | ||
|         if($cash_open!=1){
 | ||
|             $this->error('提现功能已关闭,请联系商家');
 | ||
|         }
 | ||
|         if (IS_POST) {
 | ||
|             $cash_open=tpCache('cash.cash_open');
 | ||
|             if($cash_open!=1){
 | ||
|                 $this->ajaxReturn(['status'=>0, 'msg'=>'提现功能已关闭,请联系商家']);
 | ||
|             }
 | ||
| 
 | ||
|             $data = I('post.');
 | ||
|             $data['user_id'] = $this->user_id;
 | ||
|             $data['create_time'] = time();
 | ||
|             $cash = tpCache('cash');
 | ||
| 
 | ||
|             if(encrypt($data['paypwd']) != $this->user['paypwd']){
 | ||
|                 $this->ajaxReturn(['status'=>0, 'msg'=>'支付密码错误']);
 | ||
|             }
 | ||
|             if ($data['money'] > $this->user['user_money']) {
 | ||
|                 $this->ajaxReturn(['status'=>0, 'msg'=>"本次提现余额不足"]);
 | ||
|             } 
 | ||
|             if ($data['money'] <= 0) {
 | ||
|                 $this->ajaxReturn(['status'=>0, 'msg'=>'提现额度必须大于0']);
 | ||
|             }
 | ||
| 
 | ||
|             // 统计所有0,1的金额
 | ||
|             $status = ['in','0,1'];   
 | ||
|             $total_money = Db::name('withdrawals')->where(array('user_id' => $this->user_id, 'status' => $status))->sum('money');
 | ||
|             if ($total_money + $data['money'] > $this->user['user_money']) {
 | ||
|                 $this->ajaxReturn(['status'=>0, 'msg'=>"您有提现申请待处理,本次提现余额不足"]);
 | ||
|             }
 | ||
| 
 | ||
|             if ($cash['cash_open'] == 1) {
 | ||
|                 if ($cash['service_ratio'] >= 100) {
 | ||
|                     $this->ajaxReturn(['status'=>0, 'msg'=>'手续费率配置必须小于100%!']);
 | ||
|                 }
 | ||
|                 $taxfee =  round($data['money'] * $cash['service_ratio'] / 100, 2);
 | ||
|                 // 限手续费
 | ||
|                 if ($cash['max_service_money'] > 0 && $taxfee > $cash['max_service_money']) {
 | ||
|                     $taxfee = $cash['max_service_money'];
 | ||
|                 }
 | ||
|                 if ($cash['min_service_money'] > 0 && $taxfee < $cash['min_service_money']) {
 | ||
|                     $taxfee = $cash['min_service_money'];
 | ||
|                 }
 | ||
|                 if ($taxfee >= $data['money']) {
 | ||
|                     $this->ajaxReturn(['status'=>0, 'msg'=>'手续费超过提现额度了!']);
 | ||
|                 }
 | ||
|                 $data['taxfee'] = $taxfee;
 | ||
| 
 | ||
| 
 | ||
|                 // 每次限提现额度
 | ||
|                 if ($cash['min_cash'] > 0 && $data['money'] < $cash['min_cash']) {
 | ||
|                     $this->ajaxReturn(['status'=>0, 'msg'=>'每次最少提现额度' . $cash['min_cash']]);
 | ||
|                 }
 | ||
|                 if ($cash['max_cash'] > 0 && $data['money'] > $cash['max_cash']) {
 | ||
|                     $this->ajaxReturn(['status'=>0, 'msg'=>'每次最多提现额度' . $cash['max_cash']]);
 | ||
|                 }
 | ||
| 
 | ||
|                 $status = ['in','0,1,2,3'];
 | ||
|                 $create_time = ['gt',strtotime(date("Y-m-d"))];
 | ||
|                 // 今天限总额度
 | ||
|                 if ($cash['count_cash'] > 0) {
 | ||
|                     $total_money2 = Db::name('withdrawals')->where(array('user_id' => $this->user_id, 'status' => $status, 'create_time' => $create_time))->sum('money');
 | ||
|                     if (($total_money2 + $data['money'] > $cash['count_cash'])) {
 | ||
|                         $total_money = $cash['count_cash'] - $total_money2;
 | ||
|                         if ($total_money <= 0) {
 | ||
|                             $this->ajaxReturn(['status'=>0, 'msg'=>"你今天累计提现额为{$total_money2},不能再提现了."]);
 | ||
|                         } else {
 | ||
|                             $this->ajaxReturn(['status'=>0, 'msg'=>"你今天累计提现额为{$total_money2},最多可提现{$total_money}账户余额."]);
 | ||
|                         }
 | ||
|                     }
 | ||
|                 }
 | ||
|                 // 今天限申请次数
 | ||
|                 if ($cash['cash_times'] > 0) {
 | ||
|                     $total_times = Db::name('withdrawals')->where(array('user_id' => $this->user_id, 'status' => $status, 'create_time' => $create_time))->count();
 | ||
|                     if ($total_times >= $cash['cash_times']) {
 | ||
|                         $this->ajaxReturn(['status'=>0, 'msg'=>"今天申请提现的次数已用完."]);
 | ||
|                     }
 | ||
|                 }
 | ||
|             }else{
 | ||
|                 $data['taxfee'] = 0;
 | ||
|             }
 | ||
| 
 | ||
|             if (M('withdrawals')->add($data)) {
 | ||
|                 $this->ajaxReturn(['status'=>1,'msg'=>"已提交申请",'url'=>U('User/recharge',['type'=>2])]);
 | ||
|             } else {
 | ||
|                 $this->ajaxReturn(['status'=>0,'msg'=>'提交失败,联系客服!']);
 | ||
|             }
 | ||
|         }
 | ||
| 
 | ||
|         //获取用户绑定openId
 | ||
|         $oauthUsers = M("OauthUsers")->where(['user_id'=>$this->user_id, 'oauth'=>'weixin'])->find();
 | ||
|         $openid = $oauthUsers['openid'];
 | ||
|         if(empty($oauthUsers)){
 | ||
|             $openid = Db::name('oauth_users')->where(['user_id'=>$this->user_id, 'oauth'=>'weixin'])->value('openid');
 | ||
|         }
 | ||
| 
 | ||
|         $user_extend=Db::name('user_extend')->where('user_id='.$this->user_id)->find();
 | ||
| 
 | ||
|         $this->assign('user_extend',$user_extend);
 | ||
|         $this->assign('cash_config', tpCache('cash'));//提现配置项
 | ||
|         $this->assign('user_money', $this->user['user_money']);    //用户余额
 | ||
|         $this->assign('openid',$openid);    //用户绑定的微信openid
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
|     
 | ||
|    public  function recharge(){
 | ||
|    		if(IS_POST){
 | ||
|    			$user = session('user');
 | ||
|    			$data['user_id'] = $this->user_id;
 | ||
|    			$data['nickname'] = $user['nickname'];
 | ||
|    			$data['account'] = I('account');
 | ||
|    			$data['order_sn'] = 'recharge'.get_rand_str(10,0,1);
 | ||
|    			$data['ctime'] = time();
 | ||
|    			$order_id = M('recharge')->add($data);
 | ||
|    			if($order_id){
 | ||
|    				// $url = U('Payment/getPay',array('pay_radio'=>$_REQUEST['pay_radio'],'order_id'=>$order_id));
 | ||
|                 // 为兼容微信支付
 | ||
|                 $url = U('Payment/getPay') . '?order_id=' . $order_id . '&pay_radio=' . urlencode($_REQUEST['pay_radio']);
 | ||
|                 $this->redirect($url);
 | ||
|    			}else{
 | ||
|    				$this->error('提交失败,参数有误!');
 | ||
|    			}
 | ||
|    		}
 | ||
|    		
 | ||
| 	   	$paymentList = Db::name('Plugin')->where("`type`='payment' and code!='cod' and status = 1 and  scene in(0,2)")->select();
 | ||
| 	   	$paymentList = convert_arr_key($paymentList, 'code');	   	
 | ||
| 	   	foreach($paymentList as $key => $val)
 | ||
| 	   	{
 | ||
| 	   		$val['config_value'] = unserialize($val['config_value']);
 | ||
| 	   		if($val['config_value']['is_bank'] == 2)
 | ||
| 	   		{
 | ||
| 	   			$bankCodeList[$val['code']] = unserialize($val['bank_code']);
 | ||
| 	   		}
 | ||
| 	   	}
 | ||
| 	   	$bank_img = include APP_PATH.'home/bank.php'; // 银行对应图片
 | ||
| 	   	$this->assign('paymentList',$paymentList);
 | ||
| 	   	$this->assign('bank_img',$bank_img);
 | ||
| 	   	$this->assign('bankCodeList',$bankCodeList);
 | ||
| 
 | ||
|         $type = I('type');
 | ||
|         $Userlogic = new UsersLogic();
 | ||
|         if($type == 1){
 | ||
|             $result = $Userlogic->get_account_log($this->user_id);  //用户资金变动记录
 | ||
|         }else if($type == 2){
 | ||
|             $status =  C('WITHDRAW_STATUS');
 | ||
|             $status[2] = '提现成功';
 | ||
|             $this->assign('status', $status);
 | ||
|             $result=$Userlogic->get_withdrawals_log($this->user_id);  //提现记录
 | ||
|         }else{
 | ||
|             $this->assign('status', C('RECHARGE_STATUS'));
 | ||
|             $result=$Userlogic->get_recharge_log($this->user_id);  //充值记录
 | ||
|         }
 | ||
| 
 | ||
|         // 查找最近一次充值方式
 | ||
|         $recharge_arr = Db::name('recharge')->field('pay_code')->where('user_id', $this->user_id)
 | ||
|            ->order('order_id desc')->find();
 | ||
|         $alipay = 'alipay'; //默认支付宝支付
 | ||
|         if($recharge_arr){
 | ||
|             foreach ($paymentList as  $key=>$item) {
 | ||
|                 if($key == $recharge_arr['pay_code']){
 | ||
|                     $alipay = $recharge_arr['pay_code'];
 | ||
|                 }
 | ||
|              }
 | ||
|         }
 | ||
|         $this->assign('alipay', $alipay);
 | ||
|         $this->assign('page', $result['show']);
 | ||
|         $this->assign('lists', $result['result']);
 | ||
|         return $this->fetch();
 | ||
|    }
 | ||
| 
 | ||
|     /**
 | ||
|      *  用户消息通知
 | ||
|      * @author yhj
 | ||
|      * @time 2018-6-28
 | ||
|      */
 | ||
|     public function message_notice()
 | ||
|     {
 | ||
|         $message_logic = new Message();
 | ||
|         $message_logic->checkPublicMessage();
 | ||
| 
 | ||
|         $type = I('type', 2);
 | ||
|         $user_info = session('user');
 | ||
|         $where = array(
 | ||
|             'user_id' => $user_info['user_id'],
 | ||
|             'deleted' => 0,
 | ||
|             'category' => $type
 | ||
|         );
 | ||
|         $size = $type == 0 ? 4 : 3;
 | ||
|         $userMessage = new UserMessage();
 | ||
| 
 | ||
|         $count = $userMessage->where($where)->count();
 | ||
|         $page = new Page($count, $size);
 | ||
|         $show = $page->show();
 | ||
|         $rec_id = $userMessage->where( $where)->LIMIT($page->firstRow.','.$page->listRows)->order('rec_id desc')->column('rec_id');
 | ||
|         if(empty($rec_id) && empty($count)){
 | ||
|             $list = [];
 | ||
|         } else {
 | ||
|             // 当前分页数据删除完了,前一页还有数据
 | ||
|             if(empty($rec_id) && $count > 0){
 | ||
|                 $rec_id = $userMessage->where( $where)->limit($size)->order('rec_id desc')->column('rec_id');
 | ||
|             }
 | ||
|             $list = $message_logic->sortMessageListBySendTime($rec_id, $type);
 | ||
|         }
 | ||
| 
 | ||
|         $no_read = $message_logic->getUserMessageCount();
 | ||
|         $this->assign('no_read', $no_read);
 | ||
|         $this->assign('page', $show);
 | ||
|         $this->assign('list', $list);
 | ||
|         $this->assign('count', $count);
 | ||
|         return $this->fetch('user/message_notice');
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      *  用户消息详情
 | ||
|      * @author yhj
 | ||
|      * @time 2018-6-28
 | ||
|      */    
 | ||
|     public function message_details()
 | ||
|     {
 | ||
| 
 | ||
|         $message_logic = new Message();
 | ||
|         $data['message_details'] = $message_logic->getMessageDetails(I('msg_id'), I('type', 0));
 | ||
|         $data['no_read'] = $message_logic->getUserMessageCount();
 | ||
|         $this->assign($data);        
 | ||
|         return $this->fetch('user/message_details');
 | ||
|     }
 | ||
|     /**
 | ||
|      * ajax用户消息删除请求
 | ||
|      * @author yhj
 | ||
|      * @time 2018-6-28
 | ||
|      */
 | ||
|     public function deletedMessage()
 | ||
|     {
 | ||
|         $message_logic = new Message();
 | ||
|         $res = $message_logic->deletedMessage(I('msg_id'),I('type'));
 | ||
|         $this->ajaxReturn($res);
 | ||
|     }
 | ||
|     /**
 | ||
|      * ajax设置用户消息已读
 | ||
|      * @author yhj
 | ||
|      * @time 2018-6-28
 | ||
|      */
 | ||
|     public function setMessageForRead()
 | ||
|     {
 | ||
|         $message_logic = new Message();
 | ||
|         $res = $message_logic->setMessageForRead(I('msg_id'));
 | ||
|         $this->ajaxReturn($res);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 支付密码
 | ||
|      * @return mixed
 | ||
|      */
 | ||
|     public function paypwd()
 | ||
|     {
 | ||
|         //检查是否第三方登录用户
 | ||
|         $logic = new UsersLogic();
 | ||
|         $data = $logic->get_info($this->user_id);
 | ||
|         $user = $data['result'];
 | ||
|         if(strrchr($_SERVER['HTTP_REFERER'],'/') =='/cart2.html'){  //用户从提交订单页来的,后面设置完有要返回去
 | ||
|             session('payPriorUrl',U('Mobile/Cart/cart2'));
 | ||
|         }
 | ||
|         if ($user['mobile'] == '')
 | ||
|             $this->error('请先绑定手机', U('User/mobile_validate',['source'=>'paypwd']));
 | ||
|         $step = I('step', 1);
 | ||
|         if ($step > 1) {
 | ||
|             $check = session('validate_code');
 | ||
|             if (empty($check)) {
 | ||
|                 $this->error('验证码还未验证通过', U('Home/User/paypwd'));
 | ||
|             }
 | ||
|         }
 | ||
|         if (IS_POST && $step == 3) {
 | ||
|             $userLogic = new UsersLogic();
 | ||
|             $data = I('post.');
 | ||
|             $data = $userLogic->paypwd($this->user_id, I('new_password'), I('confirm_password'));
 | ||
|             if ($data['status'] == -1)
 | ||
|                 $this->error($data['msg']);
 | ||
|             //$this->success($data['msg']);
 | ||
|             $this->redirect(U('Home/User/paypwd', array('step' => 3)));
 | ||
|             exit;
 | ||
|         }
 | ||
|         $this->assign('step', $step);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      *  点赞
 | ||
|      * @author lxl
 | ||
|      * @time  17-4-20
 | ||
|      * 拷多商家Order控制器
 | ||
|      */
 | ||
|     public function ajaxZan()
 | ||
|     {
 | ||
|         $comment_id = I('post.comment_id/d');
 | ||
|         $user_id = $this->user_id;
 | ||
|         $comment_info = M('comment')->where(array('comment_id' => $comment_id))->find();  //获取点赞用户ID
 | ||
|         $comment_user_id_array = explode(',', $comment_info['zan_userid']);
 | ||
|         if (in_array($user_id, $comment_user_id_array)) {  //判断用户有没点赞过
 | ||
|             $result['success'] = 0;
 | ||
|         } else {
 | ||
|             array_push($comment_user_id_array, $user_id);  //加入用户ID
 | ||
|             $comment_user_id_string = implode(',', $comment_user_id_array);
 | ||
|             $comment_data['zan_num'] = $comment_info['zan_num'] + 1;  //点赞数量加1
 | ||
|             $comment_data['zan_userid'] = $comment_user_id_string;
 | ||
|             M('comment')->where(array('comment_id' => $comment_id))->save($comment_data);
 | ||
|             $result['success'] = 1;
 | ||
|         }
 | ||
|         exit(json_encode($result));
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 删除足迹
 | ||
|      * @author lxl
 | ||
|      * @time  17-4-20
 | ||
|      * 拷多商家User控制器
 | ||
|      */
 | ||
|     public function del_visit_log(){
 | ||
| 
 | ||
|         $visit_id = I('visit_id/d' , 0);
 | ||
|         $row = Db::name('goods_visit')->where(['visit_id'=>$visit_id])->delete();
 | ||
|         if($row>0){
 | ||
|             $this->ajaxReturn(['status'=>1 , 'msg'=> '删除成功']);
 | ||
|         }else{
 | ||
|             $this->ajaxReturn(['status'=>-1 , 'msg'=> '删除失败']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 我的足迹
 | ||
|      * @author lxl
 | ||
|      * @time  17-4-20
 | ||
|      * 拷多商家User控制器
 | ||
|      * */
 | ||
|     public function visit_log()
 | ||
|     {
 | ||
|         $cat_id = I('cat_id', 0);
 | ||
|         $map['user_id'] = $this->user_id;
 | ||
|         if ($cat_id > 0) $map['a.cat_id'] = $cat_id;
 | ||
|         $count_all = Db::name('goods_visit')->where(['user_id' => $this->user_id])->count();
 | ||
|         $count = Db::name('goods_visit a')->where($map)->count();
 | ||
|         $Page = new Page($count, 20);
 | ||
|         $visit_list = Db::name('goods_visit a')->field("a.*,g.goods_name,g.shop_price")
 | ||
|             ->join('__GOODS__ g', 'a.goods_id = g.goods_id', 'LEFT')
 | ||
|             ->where($map)
 | ||
|             ->limit($Page->firstRow . ',' . $Page->listRows)
 | ||
|             ->order('a.visittime desc')
 | ||
|             ->select();
 | ||
|         $visit_log = $cates = array();
 | ||
|         $visit_total = 0;
 | ||
|         if ($visit_list) {
 | ||
|             $now = time();
 | ||
|             $endLastweek = mktime(23, 59, 59, date('m'), date('d') - date('w') + 7 - 7, date('Y'));
 | ||
|             $weekarray = array("日", "一", "二", "三", "四", "五", "六");
 | ||
|             foreach ($visit_list as $k => $val) {
 | ||
|                 if ($now - $val['visittime'] < 3600 * 24 * 7) {
 | ||
|                     if (date('Y-m-d') == date('Y-m-d', $val['visittime'])) {
 | ||
|                         $val['date'] = '今天';
 | ||
|                     } else {
 | ||
|                         if ($val['visittime'] < $endLastweek) {
 | ||
|                             $val['date'] = "上周" . $weekarray[date("w", $val['visittime'])];
 | ||
|                         } else {
 | ||
|                             $val['date'] = "周" . $weekarray[date("w", $val['visittime'])];
 | ||
|                         }
 | ||
|                     }
 | ||
|                 } else {
 | ||
|                     $val['date'] = '更早以前';
 | ||
|                 }
 | ||
|                 $visit_log[$val['date']][] = $val;
 | ||
|             }
 | ||
|             $cates = Db::name('goods_visit a')->field('cat_id,COUNT(cat_id) as csum')->where($map)->group('cat_id')->select();
 | ||
|             $cat_ids = get_arr_column($cates,'cat_id');
 | ||
|             $cateArr = Db::name('goods_category')->whereIN('id', array_unique($cat_ids))->getField('id,name'); //收藏商品对应分类名称
 | ||
|             foreach ($cates as $k => $v) {
 | ||
|                 if (isset($cateArr[$v['cat_id']])) $cates[$k]['name'] = $cateArr[$v['cat_id']];
 | ||
|                 $visit_total += $v['csum'];
 | ||
|             }
 | ||
|         }
 | ||
|         $this->assign('visit_total', $visit_total);
 | ||
|         $this->assign('count', $count_all);
 | ||
|         $this->assign('catids', $cates);
 | ||
|         $this->assign('page', $Page->show());
 | ||
|         $this->assign('visit_log', $visit_log); //浏览记录
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
|     public function myCollect()
 | ||
|     {
 | ||
|         $item = input('item', 12);
 | ||
|         $goodsCollectModel = new GoodsCollect();
 | ||
|         $user_id = $this->user_id;
 | ||
|         $goodsList = $goodsCollectModel->with('goods')->where('user_id', $user_id)->limit($item)->order('collect_id', 'desc')->select();
 | ||
|         foreach($goodsList as $key=>$goods){
 | ||
|             $goodsList[$key]['url'] = $goods->url;
 | ||
|             $goodsList[$key]['imgUrl'] = goods_thum_images($goods['goods_id'], 160, 160);
 | ||
|         }
 | ||
|         if ($goodsList) {
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '获取成功', 'result' => $goodsList]);
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '没有记录', 'result' => '']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 历史记录
 | ||
|      */
 | ||
|     public function historyLog(){
 | ||
|         $item = input('item', 12);
 | ||
|         $goodsCollectModel = new GoodsVisit();
 | ||
|         $user_id = $this->user_id;
 | ||
|         $goodsList = $goodsCollectModel->with('goods')->where('user_id', $user_id)->limit($item)->order('visit_id', 'desc')->select();
 | ||
|         foreach($goodsList as $key=>$goods){
 | ||
|             $goodsList[$key]['url'] = $goods->url;
 | ||
|             $goodsList[$key]['imgUrl'] = goods_thum_images($goods['goods_id'], 160, 160);
 | ||
|         }
 | ||
|         if ($goodsList) {
 | ||
|             $this->ajaxReturn(['status' => 1, 'msg' => '获取成功', 'result' => $goodsList]);
 | ||
|         } else {
 | ||
|             $this->ajaxReturn(['status' => 0, 'msg' => '没有记录', 'result' => '']);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * vip充值
 | ||
|      */
 | ||
|     public function rechargevip(){
 | ||
|         if (IS_POST) {
 | ||
|             $user = session('user');
 | ||
|             $map['user_id'] = $user['user_id'];
 | ||
|             $map['buy_vip'] = 1;
 | ||
|             $map['pay_status'] = 1;
 | ||
|             $info = Db::name('recharge')->where($map)->order('order_id desc')->find();
 | ||
|             if (($info['pay_time'] + 86400 * 365) > time() && $user['is_vip'] == 1) {
 | ||
|             	$this->error('您已是VIP且未过期,无需重复充值办理该业务!');
 | ||
|             }
 | ||
| 
 | ||
|             $data['user_id']    = $this->user_id;
 | ||
|             $data['nickname']   = $user['nickname'];
 | ||
|             $data['account']    = I('account');
 | ||
|             $data['order_sn']   = 'recharge' . get_rand_str(10, 0, 1);
 | ||
|             $data['buy_vip']    = 1;
 | ||
|             $data['ctime']  = time();
 | ||
|             $order_id = Db::name('recharge')->add($data);
 | ||
|             if ($order_id) {
 | ||
|                 $url = U('Home/Payment/getPay', array('pay_radio' => $_REQUEST['pay_radio'], 'order_id' => $order_id));
 | ||
|                 $this->redirect($url);
 | ||
|             } else {
 | ||
|                 $this->error('提交失败,参数有误!');
 | ||
|             }
 | ||
|         }
 | ||
|         $paymentList = Db::name('Plugin')->cache(true)->where("`type`='payment' and code!='cod' and status = 1 and scene in(0,2)")->select();
 | ||
|         $paymentList = convert_arr_key($paymentList, 'code');
 | ||
|         foreach ($paymentList as $key => $val) {
 | ||
|             $val['config_value'] = unserialize($val['config_value']);
 | ||
|             if ($val['config_value']['is_bank'] == 2) {
 | ||
|                 $bankCodeList[$val['code']] = unserialize($val['bank_code']);
 | ||
|             }
 | ||
|         }
 | ||
|         $bank_img = include APP_PATH . 'home/bank.php'; // 银行对应图片
 | ||
|         $this->assign('paymentList', $paymentList);
 | ||
|         $this->assign('bank_img', $bank_img);
 | ||
|         $this->assign('bankCodeList', $bankCodeList);
 | ||
|         return $this->fetch();
 | ||
|     }
 | ||
| 
 | ||
| } | 
