使用JSSDK需要前后端的合作,后端为前端提供JSSDK需要的信息,前端进行JSAPI的调用,其中后端的难点在于如何去生成前端需要的签名
官方文档(附录1-JS-SDK使用权限签名算法)
生成签名的主要步骤
- 获取access_token
- 通过第一步获取的access_token去获取jsapi_ticket
- 利用签名算法生成签名
- 前端通过调用生成签名的接口获得签名等信息
A. 获取access_token
access_token是采用http GET方式获取的($a,$s分别为你的appid和appsecret)
url: https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$a&secret=$s
通过开发者工具中的接口调试工具,可以测试你能否正确获取到access_token,如果返回的提示是++Request successful++,则说明能成功获取access_token
// 成功获取后,微信会返回一个access_token和一个过期时间expires_in
{
"access_token": "XXX",
"expires_in": 7200
}
// 失败时则返回errcode和errmsg
{
"errcode": 40125,
"errmsg": ""
}
获取access_token之后,需要把它缓存起来,可以通过把微信返回的信息保存为文件,也可以通过把信息保存到数据库,我是通过把信息存到数据库的
PHP 代码如下:
public function getAccessToken() {
// access_token 应该全局存储与更新
// 获取数据库中的access_token
$token = M('accesstoken')->limit(1)->find();
// 如果数据库存在token
if ($token) {
// 格式化数据库的timestamp
$time = strtotime($token['time']);
}
// accessToken过期或不存在时
if($time + $token[