node.js 微信开发之定时获取access_token
什么是access_token
access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效
当你的多个微信开发相关服务并存时,多个服务各自去获取access_token,最后导致其中一些服务会不能正常访问.
所以这种情况下,应该设置一个获取access_token的中控服务器.
因为access_token的有效期为2个小时,
所以你的中控服务器必须能够定时去拉取最新的access_token.
下面我们设置一个非常简单的中控服务器
此中控服务器需要有以下几个特点:
1.可以定时执行
2.拉取到最新access_token可以持久化
3.持久化的access_token可以被其他相关服务访问到.
node.js下定时任务
我们采用node-schedule
npminstallnode-schedule--save
schedule.scheduleJob(A,B)
scheduleJob方法接收2个参数,A为日期规则(多长时间执行) B为回调方法(当日期符合条件时,将要做什么)
先来看下参数A:
##六颗星方式
‘******'
┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ |
│ │ │ │ │ └星期几(0-7)(0或者7表示星期日)
│ │ │ │ └─────月份(1-12)
│ │ │ └──────────日期(1-31)
│ │ └───────────────小时(0-23)
│ └────────────────────分钟(0-59)
└─────────────────────────秒(0-59)
下面用此方式我们约定在8月30日0点0分0秒执行程序.
对应的参数A设置如下:
‘000308*'
varm=schedule.scheduleJob('000308*',function(){ getToken(); });
上面的getToken()是我自定义的一个获取微信access_token的方法,下面会有说明.
设置每30秒执行一次定时任务
‘30*****'
设置每1分30秒执行一次任务
‘301****'
设置凌晨0点1分30秒执行任务
‘3010***'
RecurrenceRule方式
//定义一个时间规则 varrule=newschedule.RecurrenceRule(); //rule.dayOfWeek=0; //rule.month=0; //rule.dayOfMonth=0; //rule.hour=0; //rule.minute=0; rule.second=0; schedule.scheduleJob(rule,function(){ getToken(); });
创建了一个RecurrenceRule对象,它有6个属性,分别对应星期,月份,日期,小时,分钟,秒
通过各个参数来设置你的时间规则器.
上面介绍了 node.js下使用node-schedule来执行定时任务,下面我们来看下如何获取微信access_token
获取微信access_token
GET请求方式:
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={APPID}&secret={APPSECRET}
注意上面的{APPID}和{APPSECRET}要登录微信公众后台获取.
下面我们使用request来提交一个get请求即可:
npminstallrequest--save
我们还用到了redis,npminstallredis--save
varclient=redis.createClient({ "host":"127.0.0.1", "port":"6379" }); vargetToken=function(){ varurl=util.format('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s',wechat.appid,wechat.secret); request(url,function(error,response,body){ if(!error&&response.statusCode==200){ varbodyToken=JSON.parse(body); if(bodyToken&&bodyToken.access_token){ setToken(bodyToken.access_token); } } }) } varsetToken=function(token){ if(token){ client.set("YG-WECHAT-TOKEN",token); } }
每小时执行一次定时任务getToken()
拿到最新access_token后存储在redis中,key为YG-WECHAT-TOKEN
获取access_token
上面的流程我们已经每小时让定时任务拿到了最新的access_token,并且持久化到了redis中.
其他服务如何获取access_token呢?
直接连接redis服务,根据key获取对应的token.
当然你也可以写一个统一的接口,通过接口拿到access_token.
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。