123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- <?php
- namespace addons\epay\library;
- use fast\Http;
- use think\Cache;
- use think\Session;
- class Wechat
- {
- private $app_id = '';
- private $app_secret = '';
- private $scope = 'snsapi_userinfo';
- public function __construct($app_id, $app_secret)
- {
- $this->app_id = $app_id;
- $this->app_secret = $app_secret;
- }
-
- public function getAuthorizeUrl()
- {
- $redirect_uri = addon_url('epay/api/wechat', [], true, true);
- $redirect_uri = urlencode($redirect_uri);
- $state = \fast\Random::alnum();
- Session::set('state', $state);
- return "https://open.weixin.qq.com/connect/oauth2/authorize?appid={$this->app_id}&redirect_uri={$redirect_uri}&response_type=code&scope={$this->scope}&state={$state}#wechat_redirect";
- }
-
- public function getOpenid()
- {
- $openid = Session::get('openid');
- if (!$openid) {
- if (!isset($_GET['code'])) {
- $url = $this->getAuthorizeUrl();
- Header("Location: $url");
- exit();
- } else {
-
- $code = $_GET['code'];
- $token = $this->getAccessToken($code);
- if (!isset($token['openid']) && isset($token['errmsg'])) {
- exception($token['errmsg']);
- }
- $openid = isset($token['openid']) ? $token['openid'] : '';
- if ($openid) {
- Session::set("openid", $openid);
- }
-
- }
- }
- return $openid;
- }
-
- public function getAccessToken($code = '')
- {
- $params = [
- 'appid' => $this->app_id,
- 'secret' => $this->app_secret,
- 'code' => $code,
- 'grant_type' => 'authorization_code'
- ];
- $ret = Http::sendRequest('https://api.weixin.qq.com/sns/oauth2/access_token', $params, 'GET');
- if ($ret['ret']) {
- $ar = json_decode($ret['msg'], true);
- return $ar;
- }
- return [];
- }
- public function getJsticket($code = '')
- {
- $jsticket = Session::get('jsticket');
- if (!$jsticket) {
- $token = $this->getAccessToken($code);
- $params = [
- 'access_token' => 'token',
- 'type' => 'jsapi',
- ];
- $ret = Http::sendRequest('https://api.weixin.qq.com/cgi-bin/ticket/getticket', $params, 'GET');
- if ($ret['ret']) {
- $ar = json_decode($ret['msg'], true);
- return $ar;
- }
- }
- return $jsticket;
- }
- public function getSignPackage($url) {
- $jsapiTicket = $this->getWechatJsApiTicket();
-
- $timestamp = time();
- $nonceStr = $this->getRandString(16);
-
- $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr×tamp=$timestamp&url=$url";
- $signature = sha1($string);
- $signPackage = array(
- "appId" => $this->app_id,
- "nonceStr" => $nonceStr,
- "timestamp" => $timestamp,
- "url" => $url,
- "signature" => $signature,
- "rawString" => $string
- );
- return $signPackage;
- }
-
- public function getWechatBasicAccesstoken($updatenow = false)
- {
-
-
-
- $access_token = cache('access_token');
-
- if(!$access_token || $updatenow) {
- $rs = json_decode(curl_get('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid='.$this->app_id.'&secret='.$this->app_secret), true);
- if(!empty($rs['errmsg'])) {
- abort(500, $rs['errmsg']);
- }
-
- $access_token = $rs['access_token'];
- cache('access_token', $access_token, $rs['expires_in'] - 1000);
- }
- return $access_token;
- }
-
- private function getWechatJsApiTicket($updatenow = false)
- {
-
-
- $ticket = cache('jsapi_ticket');
-
- if(!$ticket || $updatenow) {
-
- $access_token = $this->getWechatBasicAccesstoken();
-
- $rs = json_decode(curl_get('https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token='.$access_token.'&type=jsapi'), true);
- if($rs['errmsg'] != 'ok') {
- $access_token = $this->getWechatBasicAccesstoken(true);
- $rs = json_decode(curl_get('https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token='.$access_token.'&type=jsapi'), true);
- if($rs['errmsg'] != 'ok') {
- abort(500, $rs['errmsg']);
- }
- }
-
- $ticket = $rs['ticket'];
- cache('jsapi_ticket', $ticket, $rs['expires_in'] - 1000);
- }
- return $ticket;
- }
-
- private function getRandString($length = 1)
- {
- $str = null;
- $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
- $max = strlen($strPol) - 1;
- for($i = 0; $i < $length; $i++) {
- $str .= $strPol[rand(0, $max)];
- }
- return $str;
- }
- }
|