이 글에서는 액세스 토큰을 저장하고 업데이트하는 방법을 소개합니다.
access_token은 공식 계정의 전역 고유 티켓으로 각 인터페이스를 호출할 때 access_token을 사용해야 합니다. 일반적인 상황에서는 access_token이 7200초 동안 유효합니다. 반복적으로 획득하면 마지막 access_token이 무효화됩니다.
공식 계정은 AppID 및 AppSecret을 사용하여 이 인터페이스를 호출하여 access_token을 얻을 수 있습니다. AppID, AppSecret은 개발모드에서 획득 가능합니다. (개발자여야 하며, 계정에 이상이 없어야 합니다.) 모든 WeChat 인터페이스를 호출할 때는 https 프로토콜을 사용해야 합니다.
인터페이스 호출 요청 설명
http请求方式: GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
매개변수 설명
参数 | 是否必须 | 说明 |
---|---|---|
grant_type | 是 | 获取access_token填写client_credential |
appid | 是 | 第三方用户唯一凭证 |
secret | 是 | 第三方用户唯一凭证密钥,既appsecret |
반환 설명
일반적인 상황에서 WeChat은 다음 JSON 데이터 패킷을 공개 계정에 반환합니다:
{"access_token":"ACCESS_TOKEN","expires_in":7200}
3. 구현
class class_weixin { var $appid = APPID; var $appsecret = APPSECRET; //构造函数,获取Access Token public function __construct($appid = NULL, $appsecret = NULL) { if($appid && $appsecret){ $this->appid = $appid; $this->appsecret = $appsecret; } //1. 数据库形式 /* DROP TABLE IF EXISTS `wx_token`; CREATE TABLE IF NOT EXISTS `wx_token` ( `id` int(1) NOT NULL, `type` varchar(20) NOT NULL, `expire` varchar(16) NOT NULL, `value` varchar(600) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; INSERT INTO `wx_token` (`id`, `type`, `expire`, `value`) VALUES (1, 'access_token', '1425534992', 't3oyW9fRnOWKQHQhZXoEH-pgThhjmnCqTVpaLyUD'), (2, 'jsapi_ticket', '', ''); */ $con = mysql_connect(MYSQLHOST.':'.MYSQLPORT, MYSQLUSER, MYSQLPASSWORD); mysql_select_db(MYSQLDATABASE, $con); $result = mysql_query("SELECT * FROM `wx_token` WHERE `type` = 'access_token'"); while($row = mysql_fetch_array($result)) { $this->access_token = $row['value']; $this->expires_time = $row['expire']; break; } if (time() > ($this->expires_time + 3600)){ $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret; $res = $this->http_request($url); $result = json_decode($res, true); $this->access_token = $result["access_token"]; $this->expires_time = time(); mysql_query("UPDATE `wx_token` SET `expire` = '$this->expires_time', `value` = '$this->access_token' WHERE `type` = 'access_token';"); } //2. 缓存形式 if (isset($_SERVER['HTTP_APPNAME'])){ //SAE环境,需要开通memcache $mem = memcache_init(); }else { //本地环境,需已安装memcache $mem = new Memcache; $mem->connect('localhost', 11211) or die ("Could not connect"); } $this->access_token = $mem->get($this->appid); if (!isset($this->access_token) || empty($this->access_token)){ $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret; $res = $this->http_request($url); $result = json_decode($res, true); $this->access_token = $result["access_token"]; $mem->set($this->appid, $this->access_token, 0, 3600); } //3. 本地写入 $res = file_get_contents('access_token.json'); $result = json_decode($res, true); $this->expires_time = $result["expires_time"]; $this->access_token = $result["access_token"]; if (time() > ($this->expires_time + 3600)){ $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret; $res = $this->http_request($url); $result = json_decode($res, true); $this->access_token = $result["access_token"]; $this->expires_time = time(); file_put_contents('access_token.json', '{"access_token": "'.$this->access_token.'", "expires_time": '.$this->expires_time.'}'); } //4. 实时拉取 $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret; $res = $this->http_request($url); $result = json_decode($res, true); $this->access_token = $result["access_token"]; $this->expires_time = time(); }
WeChat 공개 플랫폼 개발 및 WeChat 액세스 토큰 자동 업데이트와 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!