201 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			201 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace app\index\controller;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use addons\third\library\Application;
							 | 
						||
| 
								 | 
							
								use addons\third\library\Service;
							 | 
						||
| 
								 | 
							
								use app\common\controller\Frontend;
							 | 
						||
| 
								 | 
							
								use app\common\library\Sms;
							 | 
						||
| 
								 | 
							
								use fast\Random;
							 | 
						||
| 
								 | 
							
								use think\Cookie;
							 | 
						||
| 
								 | 
							
								use think\Hook;
							 | 
						||
| 
								 | 
							
								use think\Lang;
							 | 
						||
| 
								 | 
							
								use think\Session;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * 第三方登录控制器
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								class Third extends Frontend
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    protected $noNeedLogin = ['prepare'];
							 | 
						||
| 
								 | 
							
								    protected $noNeedRight = ['*'];
							 | 
						||
| 
								 | 
							
								    protected $app = null;
							 | 
						||
| 
								 | 
							
								    protected $options = [];
							 | 
						||
| 
								 | 
							
								    protected $layout = 'default';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function _initialize()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        parent::_initialize();
							 | 
						||
| 
								 | 
							
								        $config = get_addon_config('third');
							 | 
						||
| 
								 | 
							
								        $this->app = new Application($config);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $auth = $this->auth;
							 | 
						||
| 
								 | 
							
								        //监听注册登录事件
							 | 
						||
| 
								 | 
							
								        Hook::add('user_login_successed', function ($user) use ($auth) {
							 | 
						||
| 
								 | 
							
								            $expire = input('post.keeplogin') ? 30 * 86400 : 0;
							 | 
						||
| 
								 | 
							
								            Cookie::set('uid', $user->id, $expire);
							 | 
						||
| 
								 | 
							
								            Cookie::set('token', $auth->getToken(), $expire);
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								        Hook::add('user_register_successed', function ($user) use ($auth) {
							 | 
						||
| 
								 | 
							
								            Cookie::set('uid', $user->id);
							 | 
						||
| 
								 | 
							
								            Cookie::set('token', $auth->getToken());
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 准备绑定
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function prepare()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $platform = $this->request->request('platform', '');
							 | 
						||
| 
								 | 
							
								        if (!in_array($platform, ['wechat', 'weibo', 'qq'])) {
							 | 
						||
| 
								 | 
							
								            $this->error("未找到指定平台");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $url = $this->request->get('url', '/', 'trim,xss_clean');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        // 授权成功后的回调
							 | 
						||
| 
								 | 
							
								        $thirdinfo = Session::get("third-{$platform}");
							 | 
						||
| 
								 | 
							
								        if (!$thirdinfo) {
							 | 
						||
| 
								 | 
							
								            $this->error("操作失败,请返回重试");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $apptype = Service::getApptype();
							 | 
						||
| 
								 | 
							
								        $openid = $thirdinfo['openid'] ?? '';
							 | 
						||
| 
								 | 
							
								        $unionid = $thirdinfo['unionid'] ?? '';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        // 如果是登录状态,直接跳到绑定
							 | 
						||
| 
								 | 
							
								        if ($this->auth->id) {
							 | 
						||
| 
								 | 
							
								            $isBind = Service::isBindThird($platform, $openid, '', $unionid);
							 | 
						||
| 
								 | 
							
								            if ($isBind) {
							 | 
						||
| 
								 | 
							
								                $this->error("已经绑定其它账号,无法进行绑定");
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            $this->redirect(url("index/third/bind") . "?" . http_build_query(['platform' => $platform, 'url' => $url]));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if ($this->request->isPost()) {
							 | 
						||
| 
								 | 
							
								            $mobile = $this->request->post("mobile");
							 | 
						||
| 
								 | 
							
								            $platform = $this->request->post("platform");
							 | 
						||
| 
								 | 
							
								            $captcha = $this->request->post("captcha");
							 | 
						||
| 
								 | 
							
								            $nickname = $thirdinfo['userinfo']['nickname'] ?? '';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            if (!Sms::check($mobile, $captcha, 'bind')) {
							 | 
						||
| 
								 | 
							
								                $this->error(__('验证码不正确'));
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            $user = \app\common\model\User::where('mobile', $mobile)->find();
							 | 
						||
| 
								 | 
							
								            if ($user) {
							 | 
						||
| 
								 | 
							
								                $isBind = \addons\third\model\Third::where('platform', $platform)->where('user_id', $user['id'])->find();
							 | 
						||
| 
								 | 
							
								                if ($isBind) {
							 | 
						||
| 
								 | 
							
								                    $this->error('该手机号已经占用');
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                $result = $this->auth->direct($user->id);
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								                $extend = array_filter(['nickname' => $nickname]);
							 | 
						||
| 
								 | 
							
								                $result = $this->auth->register($mobile, Random::alnum(), '', $mobile, $extend);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            // 账号创建成功则添加绑定第三方绑定
							 | 
						||
| 
								 | 
							
								            if ($result) {
							 | 
						||
| 
								 | 
							
								                \addons\third\model\Third::create(['user_id' => $this->auth->id, 'platform' => $platform, 'apptype' => $apptype, 'openid' => $openid, 'unionid' => $unionid, 'openname' => $nickname], true);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            //删除临时Session
							 | 
						||
| 
								 | 
							
								            Session::delete("third-{$platform}");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            //绑定成功,跳转到之前页面
							 | 
						||
| 
								 | 
							
								            $this->success("绑定成功", $url);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $this->view->assign('userinfo', $thirdinfo['userinfo']);
							 | 
						||
| 
								 | 
							
								        $this->view->assign('platform', $platform);
							 | 
						||
| 
								 | 
							
								        $this->view->assign('url', $url);
							 | 
						||
| 
								 | 
							
								        $this->view->assign('bindurl', url("index/third/bind") . '?' . http_build_query(['platform' => $platform, 'url' => $url]));
							 | 
						||
| 
								 | 
							
								        $this->view->assign('captchaType', config('fastadmin.user_register_captcha'));
							 | 
						||
| 
								 | 
							
								        $this->view->assign('title', "账号绑定");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return $this->view->fetch();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 绑定账号
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function bind()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $platform = $this->request->request('platform', '');
							 | 
						||
| 
								 | 
							
								        if (!in_array($platform, ['wechat', 'weibo', 'qq'])) {
							 | 
						||
| 
								 | 
							
								            $this->error("未找到指定平台");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $url = $this->request->get('url', $this->request->server('HTTP_REFERER', '', 'trim'), 'trim');
							 | 
						||
| 
								 | 
							
								        if (!$platform) {
							 | 
						||
| 
								 | 
							
								            $this->error("参数不正确");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $apptype = $platform == 'wechat' ? Service::getApptype() : '';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        // 授权成功后的回调
							 | 
						||
| 
								 | 
							
								        $thirdinfo = Session::get("third-{$platform}");
							 | 
						||
| 
								 | 
							
								        if (!$thirdinfo) {
							 | 
						||
| 
								 | 
							
								            $this->redirect(addon_url('third/index/connect', [':platform' => $platform]) . '?url=' . urlencode($url));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $third = \addons\third\model\Third::where('user_id', $this->auth->id)->where('platform', $platform)->find();
							 | 
						||
| 
								 | 
							
								        if ($third) {
							 | 
						||
| 
								 | 
							
								            $this->error("已绑定账号,请勿重复绑定");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $time = time();
							 | 
						||
| 
								 | 
							
								        $values = [
							 | 
						||
| 
								 | 
							
								            'platform'      => $platform,
							 | 
						||
| 
								 | 
							
								            'apptype'       => $apptype,
							 | 
						||
| 
								 | 
							
								            'user_id'       => $this->auth->id,
							 | 
						||
| 
								 | 
							
								            'unionid'       => $thirdinfo['unionid'] ?? '',
							 | 
						||
| 
								 | 
							
								            'openid'        => $thirdinfo['openid'],
							 | 
						||
| 
								 | 
							
								            'openname'      => $thirdinfo['userinfo']['nickname'] ?? '',
							 | 
						||
| 
								 | 
							
								            'access_token'  => $thirdinfo['access_token'],
							 | 
						||
| 
								 | 
							
								            'refresh_token' => $thirdinfo['refresh_token'],
							 | 
						||
| 
								 | 
							
								            'expires_in'    => $thirdinfo['expires_in'],
							 | 
						||
| 
								 | 
							
								            'logintime'     => $time,
							 | 
						||
| 
								 | 
							
								            'expiretime'    => $time + $thirdinfo['expires_in'],
							 | 
						||
| 
								 | 
							
								        ];
							 | 
						||
| 
								 | 
							
								        $isBind = Service::isBindThird($platform, $values['openid'], '', $values['unionid']);
							 | 
						||
| 
								 | 
							
								        if ($isBind) {
							 | 
						||
| 
								 | 
							
								            $this->error("已经绑定其它账号,无法进行绑定");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $third = \addons\third\model\Third::create($values);
							 | 
						||
| 
								 | 
							
								        if ($third) {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            //删除临时Session
							 | 
						||
| 
								 | 
							
								            Session::delete("third-{$platform}");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            $this->success("账号绑定成功", $url);
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								            $this->error("账号绑定失败,请重试", $url);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 解绑账号
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function unbind()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $platform = $this->request->request('platform', '');
							 | 
						||
| 
								 | 
							
								        if (!in_array($platform, ['wechat', 'weibo', 'qq'])) {
							 | 
						||
| 
								 | 
							
								            $this->error("未找到指定平台");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $apptype = $platform == 'wechat' ? Service::getApptype() : '';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $third = \addons\third\model\Third::where('user_id', $this->auth->id)
							 | 
						||
| 
								 | 
							
								            ->where('platform', $platform)
							 | 
						||
| 
								 | 
							
								            ->where(function ($query) use ($platform, $apptype) {
							 | 
						||
| 
								 | 
							
								                if ($platform == 'wechat') {
							 | 
						||
| 
								 | 
							
								                    $query->where('apptype', $apptype);
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								            })
							 | 
						||
| 
								 | 
							
								            ->find();
							 | 
						||
| 
								 | 
							
								        if (!$third) {
							 | 
						||
| 
								 | 
							
								            $this->error("未找到指定的账号绑定信息");
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        Session::delete("third-{$platform}");
							 | 
						||
| 
								 | 
							
								        $third->delete();
							 | 
						||
| 
								 | 
							
								        $this->success("账号解绑成功");
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |