微信用户体系和自有用户体系之间的关系

        微信小程序因为有自身的用户体系存在,使得项目的用户管理部分在开发和使用过程中容易产生很多困惑。最近的一个项目让我对这类问题整体思考了一下。一家之言,以问答的形式整理出来,给需要的人一点思路。

openId和自己的用户体系应该做成什么关系?

        首先,我们设定一个userId为我们自己项目的用户的唯一标识。那么此时,对于某个用户来说,就有了两个唯一标识,一个是我们自身体系的userId,另一个是openId。在整个项目中,这两个都对应了唯一的用户,即根据其中任何一个都能且只能查询到一个用户。因此我们得出结论:一个openId只能同时绑定一个userId,在我们的用户表中,openId可空但是不可重复。userId不可空不可重复。

        所以,我们可以看到很多app在登录的时候提供了微信登录和微信解绑,我认为前者目的是将openId和userId绑定,后者是将openId删除。

是否允许多微信号登录同一个用户帐号?

    这个问题看似好回答,实际上有一个坑。按照第一个问题的思考,一个openId和一个userId绑定,自然这个微信号和用户绑定,怎么可能多微信登录呢?我们想两个场景:场景一,用户打开小程序,openId自动登录,获取到用户信息,登录成功;场景二,用户在小程序中用手机号验证码登录(此时openId不是手机号对应绑定的openId),理论上也应该能登录成功。

        上面第一个场景没问题。第二个场景下,就会造成此时登录成功的openId和用户系统中保存的openId不一致。开发时,要特别注意第二种情况,为了友好性,我们应该允许用户用同一个微信登录不同的帐号,但是必须要注意一点:无论登录多少帐号,openId只能和一个userId绑定。

        由以上结论也可以得到一个推论:即我们保存和查询用户业务信息时应该尽量使用userId。

微信小程序自动登录怎么做?

        继续思考上面的场景一,我们是怎么做到自动登录的呢?答案是openId,因为这个是微信小程序中唯一身份证明。在app.js中向服务端传入openId,换取userId。如果顺利换取,则登录成功;否则,说明该微信没有绑定用户,跳转到登录页面即可。这样还有一个好处,尽管别的微信登录过你的账户,只要不做微信绑定,下次他也不会自动登录上你的帐号。

如何让微信小程序登录状态失效?

        上面的自动登录有一个问题,不管用户多久没登录,只要openId绑定过user,即可自动登录。某些应用并不希望用户随时都能自动登录。

        我实现的策略是加入一个token。这个token在服务端的缓存中维护,为这个token增加一个失效时间。微信小程序登录成功之后获取一个token,以后每次登录都用这个token换取userId。如果失效期到,则登录失败,跳转到登录页面。

开发中怎么处理微信小程序的登录授权和创建用户?

        微信的授权方式可以说是越来越严格,在此不讨论具体的授权流程。我认为这两个可以同时做,也可以根据需求分开做,比如有些功能必须是登录状态才可以使用,有些功能是授权状态才可以使用。

        关于用户先就写这么多,以后想到了再补充吧。



我在开发中遇到的更多的坑都已经记录在easyDemo小程序中,希望我的demo能给你easy。我还会持续更新easyDemo,欢迎收藏。

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

推荐阅读更多精彩内容