评论

openid的获取顺序

获取openid的顺序的代码,代码量本人已经无法再压缩了。 效果:1、一定获取openid成功,2、最少占用资源;3、最少代码量。

openid的获取顺序为:

1、globalData;2、缓存Storage;3、云函数

前提:

1、不勾选es6转es5;2、不勾选增强编译;

代码如下:

app.js:

globalData: {},

//获取openid顺序:globalData--云函数login

getOpenidOnlyCloud: async function () {
  return this.globalData.openid = this.globalData.openid || (await wx.cloud.callFunction({ name: 'login' })).result.OPENID
},
 
//获取openid顺序:globalData--storage--云函数login
getOpenid: async function () {
  (this.globalData.openid = this.globalData.openid || wx.getStorageSync('openid')) || wx.setStorageSync('openid', this.globalData.openid = (await wx.cloud.callFunction({ name: 'login' })).result.OPENID)
  return this.globalData.openid
},

任何page:

onLoad: async function () {
  this.openid = await app.getOpenid()
  console.log(this.openid)
},

云函数login:

const cloud = require('wx-server-sdk')
cloud.init()
exports.main = (event) => { return { ...event,...cloud.getWXContext()} }
//可同时支持返回openid和处理cloudID,获取电话号码和群ID等信息。

达到的效果:

1、一定获取openid成功;

2、任何异步情况可支持;

3、任何用户永久只调用一次login;

4、任何用户每次重载小程序只读取一次缓存;

另:

1、为什么不在app.js的onLaunch里获取一下openid就行了?

因为并不能保证app.onLaunch一定比page.onLoad更早执行,在page里读取globalData.openid的时候可能为空。

2、我为什么要选择globalData--storage--云函数的顺序?

因为openid只要获取一次就行,保存在storage还是合理的,每次都调用云函数login那也是钱啊。

最后一次编辑于  11-28  
点赞 2
收藏
评论

2 个评论

  • fore
    fore
    11-26

    别人的我不知道,反正我们做的每个小程序都会用到openid,并且每个项目中用openid的时候,都需要确保openid已经被正确获取。目前我们基本上都是使用promise来获取,代码非常不简洁。

    官方是否可以出一个同步的api,在onLaunch时候让我调用一下???

    11-26
    赞同
    回复 4
    • 老张
      老张
      11-26
      并不是onLaunch里就一定最先获得opened,否则就太简单了,一行代码就搞定了。
      11-26
      回复
    • fore
      fore
      11-26回复老张
      期望的就是这个效果,本来就是可以一行代码调用接口的事情。
      11-26
      回复
    • fore
      fore
      11-26回复老张
      只是微信不出这样的接口,谁都没辙。非得开发人员写出一坨坨的代码。
      11-26
      回复
    • 老张
      老张
      11-26回复fore
      想也别想了。首先微信不建议在前端用openid,永远不会有这样的API。其次,代码也没多少,而且可以通用,复制就搞定。
      11-26
      回复
  • 郑旭东
    郑旭东
    11-23

    老张的语法非常精简。

    顺便我要提醒一下坛子里的其他开发者,我不建议把裸露的openid放在globalData或者storage里面,因为安全问题。云函数环境里的openid是腾讯鉴权好的,100%正确,而放在客户端的openid有被篡改的风险。所以,客户端openid可以用,仅限于用在客户端的逻辑里,严禁把客户端的openid再传递回云端使用。

    如果使用云开发作为后端的,后端逻辑里请实时获取openid,很方便。如果是自有后台,我记得开发文档里也有相关的登录开发指引,按那个指引来对openid进行session化。

    非专业后端开发,以上理解可能有偏差,请指正。

    11-23
    赞同
    回复 1
    • 老张
      老张
      11-23
      说得不错,如何使用,大家自己把握。我个人看得比较轻,一个摩托车级的小程序而已,没必要用上航母级别的安全锁。真要被人看上了来破解,那我也是偷着乐,那时再上安全方案好了。
      11-23
      回复