说明思路
微信公众平台说明:“access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效”。
而且每天一个appid只能获取2000次access_token,对于用户量较大的公众号来说很难满足需求。为了解决这个问题我们采用如下办法:首先创建数据库对获取的access_token进行保存,在其没到期之前不再获取新的access_token;如果两小时到了那么这个凭证就到期了,此时我们再向微信服务器发送请求获取新的access_token,按此方法一天24小时,我们只需要向微信服务器发送12次请求,这样既满足了我们的需求,也不会对微信服务器造成较大的压力
具体步骤
-
创建数据库 ,我们需要两个值一个用来存储从微信服务器获取的access_token,另一个来存储时间
-
根据微信提供的API接口
我们需要找到我们的appid和secret来传参,也就是我们测试号的appid和秘钥
- 编写储存和获取access_token的函数
<?php
//此处写上你自己的appid和秘钥
$appid = "8888888888";
$appsecret = "8888888888";
//链接数据库的操作
header("Content-type:text/html;charset=utf-8"); //解决乱码
mysql_connect("localhost","root","");
mysql_select_db("0405");
mysql_query("set names utf8");
$query = "SELECT * FROM tokens"; //取数据库token和time
$result = mysql_query($query);
$num = mysql_num_rows($result);
if ($num>0){ //查看数据库中是否有token
//数据库中已存在
$row = mysql_fetch_assoc($result);
$time = $row["time"];
// 当存储access_token过期时
if (time()-$time>7000){
// 用$token来存储我们获取的access_token
$token = getToken();//拿到最新的token
$time = time();//最新的时间戳
// 插入token和time
$query = "UPDATE tokens SET token='{$token}',time='{$time}'";
mysql_query($query);
echo mysql_affected_rows();
}else{
// echo "没过期";
$token = $row["token"];
}
}else{
//数据库没有保存过token,执行插入token
$token = getToken();
//获取当前的时间戳,单位是秒
$time = time();
// echo $token;
$query = "INSERT INTO tokens(token,time) VALUES('{$token}','{$time}')";
mysql_query($query);
}
function getToken(){
//获取全局变量
global $appid;
global $appsecret;
// 从微信平服务器获取token,存到我们的服务器内,如果服务器内token过期了就再来获取一次,用
httpGet()代替了file_get_contents()
$url = httpGet("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$appid}
&secret={$appsecret}");
$arr = json_decode($url,true);
return $arr["access_token"];
}
// 微信提供的获取token的函数
function httpGet($url) {
$curl = curl_init();
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_TIMEOUT, 500);
// 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用
下面2行代码打开ssl安全校验。
// 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文
件。
// curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);
// curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);
curl_setopt($curl, CURLOPT_URL, $url);
$res = curl_exec($curl);
curl_close($curl);
return $res;
}
//以上都是为了获取合理获取access_token,之后我们调用$token就可以使用这个凭证来调用接口了
?>