在开发微信公众平台如何持久化openid
问题描述:
在开发微信公众平台页面的时候,实现用户持久登录遇到的问题是,微信内的web页面要获取用户的OPENID都是要通过微信OAuth2.0机制的4个步骤:
1 第一步:用户同意授权,获取code
2 第二步:通过code换取网页授权access_token
3 第三步:刷新access_token(如果需要)
4 第四步:拉取用户信息(需scope为 snsapi_userinfo)
5 附:检验授权凭证(access_token)是否有效
在实际过程中发现这样使得网页的加载速度慢到不行,有没有什么方法可以立即获得当前的用户OPENID。或者获得之后存贮起来发方法?
我有尝试是在首次客户点击自定义菜单时就获得OPENID,然后存在本地,之后所有页面都读取这个OPENID。但这样是有漏洞的。
想问的是有没有微信公众平台能不能实现不用每次打开一个页面就要去获得一次授权来获取OPENID的方法?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
存session
存,session是可以,但我要点击另一个自定义菜单session 就没有了。又要跟微信公众账号取一次openID
分享一下我的解决办法
1. 首次授权后获得用户openID,建档存库,微信用户openID是固定、唯一的。
2. 本地建库给每一个用户分配一个passport,将该用户的openID与passport做绑定关系。
3. 之后需要获取用户openID的场景,只需要追踪该用户的passport就可以了。
不通过授权就想拿到用户 openid?题主你想都不要想,微信是不会那么做的!但是整个流程是可以优化的,snsapi_base 发起的授权,就不需要用户手动同意,往往就是一跳而过,用户不会查觉。
https://github.com/thenbsp/Wechat
存放在localStorage里
答案是不行,在微信里用到openid,必须以snsapi_base或者snsapi_userinfo形式。具体接入可以看这个:https://github.com/navyxie/wechat-develop
请问OPENID存在session里 但是session会过期 如果Session刚好过期用户再次刷新网页 就会因为缺少Code而错误 因为没有重定向授权地址 必须从最初的入口链接跳转到授权页获取openID