Cet article explique comment stocker et mettre à jour les jetons d'accès.
access_token est le ticket globalement unique du compte officiel Le compte officiel doit utiliser access_token lors de l'appel de chaque interface. Dans des circonstances normales, access_token est valide pendant 7 200 secondes. Une acquisition répétée rendra le dernier access_token invalide.
Les comptes officiels peuvent utiliser AppID et AppSecret pour appeler cette interface afin d'obtenir access_token. AppID et AppSecret peuvent être obtenus en mode développement (vous devez être développeur et votre compte n'a aucun statut anormal). Notez que le protocole https doit être utilisé lors de l'appel de toutes les interfaces WeChat.
Description de la demande d'appel de l'interface
http请求方式: GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
Description du paramètre
参数 | 是否必须 | 说明 |
---|---|---|
grant_type | 是 | 获取access_token填写client_credential |
appid | 是 | 第三方用户唯一凭证 |
secret | 是 | 第三方用户唯一凭证密钥,既appsecret |
Description du retour
Dans des circonstances normales, WeChat renverra le paquet de données JSON suivant au compte public :
{"access_token":"ACCESS_TOKEN","expires_in":7200}
3. Mise en œuvre
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(); }
Pour plus d'articles liés au développement de la plateforme publique WeChat et à la mise à jour automatique du jeton d'accès WeChat, veuillez faire attention au site Web chinois PHP !