config = new DataArray($options); } /** * 接收公众平台推送的 Ticket * @return bool|array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function setComonentTicket() { $receive = new Receive([ 'token' => $this->config->get('component_token'), 'appid' => $this->config->get('component_appid'), 'appsecret' => $this->config->get('component_appsecret'), 'encodingaeskey' => $this->config->get('component_encodingaeskey'), ]); $data = $receive->getReceive(); if (!empty($data['ComponentVerifyTicket'])) { Tools::setCache('component_verify_ticket', $data['ComponentVerifyTicket']); } return $data; } /** * 获取或刷新服务 AccessToken * @return bool|string * @throws Exceptions\LocalCacheException * @throws Exceptions\InvalidResponseException */ public function getComponentAccessToken() { $cache = 'wechat_component_access_token'; $component_access_token = Tools::getCache($cache); if (empty($$component_access_token)) { $url = 'https://api.weixin.qq.com/cgi-bin/component/api_component_token'; $result = $this->callPostApi($url, [ 'component_appid' => $this->config->get('component_appid'), 'component_appsecret' => $this->config->get('component_appsecret'), 'component_verify_ticket' => Tools::get('component_verify_ticket'), ]); if (empty($result['component_access_token'])) { throw new InvalidResponseException('GetComponentAccessToken Faild', '0'); } Tools::setCache($cache, $component_access_token, 7000); } return $component_access_token; } /** * 获取授权方的帐号基本信息 * @param string $authorizer_appid 授权公众号或小程序的appid * @return array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function getAuthorizerInfo($authorizer_appid) { $component_access_token = $this->getComponentAccessToken(); $url = "https://api.weixin.qq.com/cgi-bin/component/api_get_authorizer_info?component_access_token={$component_access_token}"; $result = $this->callPostApi($url, [ 'authorizer_appid' => $authorizer_appid, 'component_appid' => $this->config->get('component_appid'), ]); return $result; } /** * 设置授权方的选项信息 * @param string $authorizer_appid 授权公众号或小程序的appid * @param string $option_name 选项名称 * @param string $option_value 设置的选项值 * @return array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function setAuthorizerOption($authorizer_appid, $option_name, $option_value) { $component_access_token = $this->getComponentAccessToken(); $url = "https://api.weixin.qq.com/cgi-bin/component/ api_set_authorizer_option?component_access_token={$component_access_token}"; $result = $this->callPostApi($url, [ 'option_name' => $option_name, 'option_value' => $option_value, 'authorizer_appid' => $authorizer_appid, 'component_appid' => $this->config->get('component_appid'), ]); return $result; } /** * 获取预授权码 pre_auth_code * @return string * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function getPreauthCode() { $component_access_token = $this->getComponentAccessToken(); $url = "https://api.weixin.qq.com/cgi-bin/component/api_create_preauthcode?component_access_token={$component_access_token}"; $result = $this->callPostApi($url, ['component_appid' => $this->config->get('component_appid')]); if (empty($result['pre_auth_code'])) { throw new InvalidResponseException('GetPreauthCode Faild.', '0'); } return $result['pre_auth_code']; } /** * 获取授权回跳地址 * @param string $redirect_uri 回调URI * @param integer $auth_type 要授权的帐号类型 * @return bool * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function getAuthRedirect($redirect_uri, $auth_type = 3) { $pre_auth_code = $this->getPreauthCode(); $redirect_uri = urlencode($redirect_uri); $component_appid = $this->config->get('component_appid'); return "https://mp.weixin.qq.com/cgi-bin/componentloginpage?component_appid={$component_appid}&pre_auth_code={$pre_auth_code}&redirect_uri={$redirect_uri}&auth_type={$auth_type}"; } /** * 使用授权码换取公众号或小程序的接口调用凭据和授权信息 * @return bool|array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function getQueryAuthorizerInfo() { if (empty($_GET['auth_code'])) { return false; } $component_access_token = $this->getComponentAccessToken(); $url = "https://api.weixin.qq.com/cgi-bin/component/api_query_auth?component_access_token={$component_access_token}"; $result = $this->callPostApi($url, [ 'component_appid' => $this->config->get('component_appid'), 'authorization_code' => $_GET['auth_code'], ]); if (empty($result['authorizer_appid']) || empty($result['authorizer_access_token'])) { throw new InvalidResponseException('GetQueryAuthorizerInfo Faild.', '0'); } // 缓存授权公众号访问 ACCESS_TOKEN Tools::setCache("{$result['authorizer_appid']}_access_token", $result['authorizer_access_token'], 7000); return $result; } /** * 获取(刷新)授权公众号的令牌 * @param string $authorizer_appid 授权公众号或小程序的appid * @param string $authorizer_refresh_token 授权方的刷新令牌 * @return array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function refreshAccessToken($authorizer_appid, $authorizer_refresh_token) { $component_access_token = $this->getComponentAccessToken(); $url = "https:// api.weixin.qq.com /cgi-bin/component/api_authorizer_token?component_access_token={$component_access_token}"; $result = $this->callPostApi($url, [ 'authorizer_appid' => $authorizer_appid, 'authorizer_refresh_token' => $authorizer_refresh_token, 'component_appid' => $this->config->get('component_appid'), ]); if (empty($result['authorizer_access_token'])) { throw new InvalidResponseException('RefreshAccessToken Faild', '0'); } // 缓存授权公众号访问 ACCESS_TOKEN Tools::setCache("{$authorizer_appid}_access_token", $result['authorizer_access_token'], 7000); return $result; } /** * oauth 授权跳转接口 * @param string $authorizer_appid 授权公众号或小程序的appid * @param string $redirect_uri 回调地址 * @param string $scope snsapi_userinfo|snsapi_base * @return string */ public function getOauthRedirect($authorizer_appid, $redirect_uri, $scope = 'snsapi_userinfo') { $redirect_url = urlencode($redirect_uri); $component_appid = $this->config->get('component_appid'); return "https://open.weixin.qq.com/connect/oauth2/authorize?appid={$authorizer_appid}&redirect_uri={$redirect_url}" . "&response_type=code&scope={$scope}&state={$authorizer_appid}&component_appid={$component_appid}#wechat_redirect"; } /** * 通过code获取AccessToken * @param string $authorizer_appid 授权公众号或小程序的appid * @return bool|array * @throws Exceptions\LocalCacheException * @throws InvalidResponseException */ public function getOauthAccessToken($authorizer_appid) { if (empty($_GET['code'])) { return false; } $component_appid = $this->config->get('component_appid'); $component_access_token = $this->getComponentAccessToken(); $url = "https://api.weixin.qq.com/sns/oauth2/component/access_token?appid={$authorizer_appid}&code={$_GET['code']}&grant_type=authorization_code&" . "component_appid={$component_appid}&component_access_token={$component_access_token}"; $result = $this->callGetApi($url); return $result !== false ? $result : false; } /** * 创建需要的接口实例 * @param string $type 需要加载的接口实例名称 * @param string $authorizer_appid 授权公众号的appid * @return Card|Custom|Media|Menu|Oauth|Pay|Product|Qrcode|Receive|Scan|Script|Shake|Tags|Template|User|Wifi */ public function instance($type, $authorizer_appid) { $className = 'WeChat\\' . ucfirst(strtolower($type)); $config = $this->config->get(); $config['appid'] = $authorizer_appid; $config['token'] = $this->config->get('component_token'); $config['appsecret'] = $this->config->get('component_appsecret'); $config['encodingaeskey'] = $this->config->get('component_encodingaeskey'); return new $className($config); } }