微信公众平台开发之获取并存储access_token

虽然access_token可以使用在线工具获取到,但是每次都要找一下appid和appsecret,太麻烦l了。值得注意的是获取access_token的次数是有限制的,所以必须每次获取都要保存一下方便下次使用。本篇介绍如何获取并存储access_token。
使用文件来存储这些信息的(虽然可以使用数据库来存储,两者之间的效率问题有待考究)。
cfg.php配置文件

<?php
$access_token="new";
$expire_time=1516593966;//过期时间
?>

utils.php工具文件

<?php
    //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;
    }


    //修改配置文件,使用正则匹配修改
    function update_config($file,$cfg,$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*[\"\'](.*)/",$ini."=\"".$value."\";",$str);
                }
            file_put_contents($file, $str1); 
        }else{
            return false;
        }
    }
?>

main.php入口文件

include_once('cfg.php');
include_once('util.php');
$appid = 'your appid';
$appsecret = 'your secret';
$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;

}

猜你喜欢

转载自blog.csdn.net/qq_29729735/article/details/79127451