虽然access_token可以使用在线工具获取到,但是每次都要找一下appid和appsecret,太麻烦了。值得注意的是获取access_token的次数是有限制的,所以必须每次获取都要保存一下方便下次使用。本篇介绍如何获取并存储access_token。
使用文件来存储这些信息的(虽然可以使用数据库来存储,两者之间的效率问题有待考究)。
cfg.php配置文件
<?php
defined('TOKEN') or exit('Access Denied');//验证是否有入口token,否则为非法入口
$appid = 'your appid';
$appsecret = 'your secret';
$access_token="new";
$expire_time=1516593966;//过期时间
?>
utils.php工具文件
<?php
defined('TOKEN') or exit('Access Denied');
//get请求
function request_get($url){
$ch = curl_init();
$opts = array(
CURLOPT_SSL_VERIFYPEER => false,
CURLOPT_SSL_VERIFYHOST => false,
CURLOPT_TIMEOUT => 30,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_URL => $url,
);
curl_setopt_array($ch,$opts);
//执行cURL操作
$output = curl_exec($ch);
if(curl_errno($ch)){
//cURL发生错误处理操作
var_dump(curl_error($ch));
die;
}
curl_close($ch);
return $output;
}
//获取access_token 返回字符串
function getAccessToken($appid,$appsecret){
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
$output = request_get($url);
$jsoninfo = json_decode($output, true);
$access_token = $jsoninfo["access_token"];
return $access_token;
}
//echo getAccessToken($appid,$appsecret);
//修改配置文件,使用正则匹配修改
function update_config($file,$cfg,$value,$type='string'){
if(!file_exists($file)) return false;
$str = file_get_contents($file);
if(''!=$str&&$str!=null){
$str1 = '';
if($type=='int'){
$str1 = preg_replace("/".$cfg."\s*=\s*(.*)/",$cfg."=$value;",$str);
}else{
$str1 = preg_replace("/".$cfg."\s*=\s*[\"\'](.*)/",$cfg."=\"".$value."\";",$str);
}
file_put_contents($file, $str1);
}else{
return false;
}
}
?>
main.php入口文件
define("TOKEN", "tian");//入口token
include_once('cfg.php');
include_once('util.php');
$now = time();//获取当前时间
if($now>$expire_time){//判断当前时间是否大于过期时间,若大于则要重新获取
$expire_time = $now+7200;//设置过期时间,之后比较不用再计算
$access_token = getAccessToken($appid,$appsecret);//获取access_token
update_config('cfg.php','access_token',$access_token);//写文件,保存access_token
update_config('cfg.php','expire_time',$expire_time,'int');//写文件,保存过期时间
echo 'new</br>';
echo $access_token;
}else{
echo 'old</br>';
echo $access_token;
}