解析微信node开发;拿token

获取token,本着两个原则,

1、先查询是否有token,有的话判断其时间是否与上一次请求时间差是否超过7100;

a、不超过,直接用得到;

b、超过,再获取刷新;

2、没有token获取刷新token;

a、拼接地址,request.get请求token;将请求来的token保存到数据库更新,此处有技巧,

 if (!token) token = new WeChatAccessToken();

此句话为第一次请求时,生成一个token,将获得的数据,存储到token里面;保存,并返回;

   function getToken(appid, appsecret, cb) {
WeChatAccessToken.findOne({appid: appid}, function (err, token) {
if(token) {
var difference = parseInt(new Date().getTime() / 1000) - token.at;
if (difference > 7100) refreshToken(appid, appsecret, function(data, err) { cb(data, err); });
else cb(token, null);
} else refreshToken(appid, appsecret, function(data, err) { cb(data, err); });
});
} function refreshToken(appid, appsecret, cb) {
var access_token_api = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET";
var url = access_token_api.replace('APPID', appid).replace('APPSECRET', appsecret); // 参考请求: http://localhost:7000/wechat/ticket?appid=wx8160a61c2d53fb74&appsecret=aa2c953465334823e20090156527a957
request.get(url, function (error, response, body) {
if (body) {
WeChatAccessToken.findOne({appid: appid}, function (err, token) {
if (!token) token = new WeChatAccessToken();
var data = JSON.parse(body); token.appid = appid;
token.access_token = data.access_token;
token.expires_in = data.expires_in;
token.at = parseInt(new Date().getTime() / 1000);
token.save(function (err) { cb(token, err); });
});
} else cb(null, error);
});
}

仔细研读,getToken和refreshToekn方法;

上一篇:酶切位点分析(the analysis of enzyme sites)


下一篇:perl6 Net::HTTP 发送任意 url 请求例子