在开发微信公众平台如何持久化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的方法?

阅读 11.6k
7 个回答

存,session是可以,但我要点击另一个自定义菜单session 就没有了。又要跟微信公众账号取一次openID

分享一下我的解决办法
1. 首次授权后获得用户openID,建档存库,微信用户openID是固定、唯一的。
2. 本地建库给每一个用户分配一个passport,将该用户的openID与passport做绑定关系。
3. 之后需要获取用户openID的场景,只需要追踪该用户的passport就可以了。

不通过授权就想拿到用户 openid?题主你想都不要想,微信是不会那么做的!但是整个流程是可以优化的,snsapi_base 发起的授权,就不需要用户手动同意,往往就是一跳而过,用户不会查觉。

https://github.com/thenbsp/Wechat

存放在localStorage里

请问OPENID存在session里 但是session会过期 如果Session刚好过期用户再次刷新网页 就会因为缺少Code而错误 因为没有重定向授权地址 必须从最初的入口链接跳转到授权页获取openID

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题