小程序开发(一)如何建立小程序内用户体系

背景

当我们要做一个拥有登录功能的小程序时,面临的第一个问题就是如何基于小程序建立用户体系。

构建一个基于微信的用户体系的核心思想是:获取微信用户的唯一身份标识,然后用唯一标识关联或创建用户体系

唯一身份标识

微信生态内,一个微信用户的唯一标识主要有两个,OpenId和UnionId。

OpenId 是一个用户对于一个小程序/公众号的标识,开发者可以通过这个标识识别出用户。

UnionId 是一个用户对于同主体微信小程序/公众号/APP的标识,开发者需要在微信开放平台下绑定相同账号的主体。开发者可通过UnionId,实现多个小程序、公众号、甚至APP 之间的数据互通了。

在不变更主体的情况下,用户的这两个ID是永久不变的。即使,用户删掉了小程序,下次进来,仍可以使用这两个ID进行辨识。

备注:变更主体,指的是将小程序绑定到其他开放平台下。如果主体发生改变,那么该用户的 unionid 将发生变化。

获取唯一身份标识方式和流程

为了方便描述这个流程,我们直接看微信官方推荐的 login最佳实践。登录流程时序图如下所示:

小程序登录流程时序图

获取 OpenId

OpenId 是一个用户对一个小程序/公众号的标识,即使小程序更改了绑定主体,OpenId也不会变化。

获取OpenId主要经过一下几步:

  1. 小程序通过 wx.login()获取 code
  2. code 通过请求的方式,传递给后端
  3. 后端凭借 appidappsecretcode 向微信接口服务发起请求,得到 openidsession_key.

这样就可以获取用户的OpenId。但是,实际情况,服务端仅仅拿到了OpenId还是不够的。特别是,当小程序希望与其他小程序或者公众号、APP进行互通或者联动时(例如,使用小程序),我们需要使用 UnionId,来作为应用与应用之间的桥梁。

因此,当存在多个应用需要互通的场景时,不可以使用 OpenId作为唯一标识,因为 OpenId仅针对单个应用而言。推荐使用 UnionId作为用户的唯一标识,在多个应用之间,它都是不变且唯一。

获取UnionId

获取 UnionId 的方式,可以归为两种:

  1. 静默获取UnionId(不一定可以获取UnionId方式)。使用 code 方式,获取 UnionId(只有特定场景,才能获取到)
  2. 解析加密数据获取UnionId(一定可以获取到UnionId方式)。小程序内通过 getUserInfo,获取到加密数据后,将code和加密数据传递给后端。后端通过 code,获取 session_key,然后使用 session_key解密加密数据,获取 UnionId。

方式一:静默获取UnionId

静默获取unionId方式,是在获取 openId的方式上,增加了返回UnionId的字段。具体流程见图

code方式获取UnionId

静默获取UnionId的条件:
1.在微信开放平台下存在同主体的App、公众号、小程序。

2.用户关注了某个相同主体公众号,或曾经在某个相同主体App、公众号上进行过微信登录授权。

也就是说,如果用户没有关注过同主体的公众号,也没有在系统主题APP、公众号进行微信登录授权,那么就会获取不到UnionId.

方式二:解析加密数据获取UnionId

获取步骤:

  1. 调用 wx.login获取code
  2. 调用wx.getUserInfo获取加密数据 rawdata
  3. 服务端根据 code,获取 session_key,通过 session_key解密解密数据 rawdata,获取 UnionId

实践中的登录流程

方式一:
当已创建用户,且可以通过code获取UnionId,步骤如下:

  1. 调用 wx.login获取code
  2. 服务端根据 code,获取 OpenIdUnionId.
  3. UnionId存在,根据 UnionId,查询用户是否存在,若存在,则返回登录态;否则,报异常给小程序端
  4. 小程序根据异常,执行 「方式二」

方式二:

  1. 调用 wx.login获取 code
  2. 调用 wx.getUserInfo获取加密数据 rawdatauserinfo
  3. 客户端将coderawdatauserinfo发送给服务端
  4. 服务端根据 code,获取 session_keyOpenIdUnionId.
  5. UnionId存在,执行步骤 (7)
  6. UnionId不存在,根据session_key,服务端解密rawdata,得到 UnionId.
  7. 根据UnionId检查用户是否存在,若存在返回登录态,否则,根据UnionIdOpenIdUserinfo创建用户,并返回登录态

虽然,服务端可以从 rawdata 解析得到 userinfo,但是我们不一定会进行rawdata的解析(根据code,是否返回UnionId决定),因此,我们还是需要前端将userinfo 发送给后端。

为了更好的用户体验,对于曾经登录过的用户,避免出现授权弹窗,可以使用方式一进行登录。这样用户就可以不用手动授权即可完成登录。方式二,必须进行用户授权才可以进行登录。

未解决的问题

在开发过程,遇到了一些问题,暂时未能解决。例如,如何在小程序内唤起APP,读取APP中的用户信息,从而将APP的用户与微信用户进行绑定。

总结

本篇主要讲述了在小程序内建立用户体系的流程,以及获取唯一身份标识的方式,和实践中的登录方式。本篇并不涉及代码,具体代码部分,我们将在下篇进行讲解。

参考资料

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容