1)两种access_token,网页授权access_token和普通access_token
1、微信网页授权是通过OAuth2.0机制实现的,在用户授权给公众号后,公众号可以获取到一个网页授权特有的接口调用凭证(网页授权access_token),通过网页授权access_token可以进行授权后接口调用,如获取用户基本信息。
2、其他微信接口,需要通过基础支持中的“获取access_token”接口来获取到的普通access_token调用。access_token是公众号的全局唯一票据,access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。
2)分别获取access_token
可以看到通过code换取网页授权access_token,而这个code是通过微信的一个授权链接获取到的,然后再根据文档中的请求获取到的,具体的链接地址和参数可以参考文档。
这里需要注意的是,获取到的token,是有时效性的,2 个小时,所以我会保存在MongoDB中,先从数据库中比对超时了没有,没有的话就直接从数据库中获取,减少不必要的请求。
在微信的入口页面中,也就是前面提到的URL(服务器地址),会在这里面做保存日志的逻辑。逻辑包括关注的时候推送一条消息,二维码扫描关注,点击某个菜单产生事件,点击菜单的超链接等。
日志结构如下:
1、代码中包括签名验证逻辑
2、通过file_get_contents('php://input')来获取请求数据,就是下面的getRawMsg方法
3、将推送日志直接塞入到MongoDB中
4、将接收到的请求信息SimpleXMLElement对象,就是下面的parseMsg方法
5、handleEventMsg就是在处理各种不同情况了
6、如果要推送消息,die这个方法得要加上
7、下面的代码只列举了两种事件情况,一种是订阅、一种是点击事件
demo下载:
本文转自 咖啡机(K.F.J) 博客园博客,原文链接:http://www.cnblogs.com/strick/p/4747374.html,如需转载请自行联系原作者