收藏
评论

小程序登录、用户信息相关接口调整说明官方

公告更新时间:2021年04月15日

考虑到近期开发者对小程序登录、用户信息相关接口调整的相关反馈,为优化开发者调整接口的体验,回收wx.getUserInfo接口可获取用户授权的个人信息能力的截止时间由2021年4月13日调整至2021年4月28日24时。

为优化用户的使用体验,平台将进行以下调整:

  1. 2021年2月23日起,若小程序已在微信开放平台进行绑定,则通过wx.login接口获取的登录凭证可直接换取unionID
  2. 2021年4月28日24时后发布的小程序新版本,无法通过wx.getUserInfo与<button open-type="getUserInfo"/>获取用户个人信息(头像、昵称、性别与地区),将直接获取匿名数据(包括userInfo与encryptedData中的用户个人信息),获取加密后的openID与unionID数据的能力不做调整。此前发布的小程序版本不受影响,但如果要进行版本更新则需要进行适配。
  3. 新增getUserProfile接口(基础库2.10.4版本开始支持),可获取用户头像、昵称、性别及地区信息,开发者每次通过该接口获取用户个人信息均需用户确认。具体接口文档:《getUserProfile接口文档》
  4. 由于getUserProfile接口从2.10.4版本基础库开始支持(覆盖微信7.0.9以上版本),考虑到开发者在低版本中有获取用户头像昵称的诉求,对于未支持getUserProfile的情况下,开发者可继续使用getUserInfo能力。开发者可参考getUserProfile接口文档中的示例代码进行适配。

请使用了wx.getUserInfo接口或<button open-type="getUserInfo"/>的开发者尽快适配。开发者工具1.05.2103022版本开始支持getUserProfile接口调试,开发者可下载该版本进行改造。

小游戏不受本次调整影响。

一、调整背景

很多开发者在打开小程序时就通过组件方式唤起getUserInfo弹窗,如果用户点击拒绝,无法使用小程序,这种做法打断了用户正常使用小程序的流程,同时也不利于小程序获取新用户。

二、调整说明

通过wx.login接口获取的登录凭证可直接换取unionID

若小程序已在微信开放平台进行绑定,原wx.login接口获取的登录凭证若需换取unionID需满足以下条件:

  1. 如果开发者帐号下存在同主体的公众号,并且该用户已经关注了该公众号
  2. 如果开发者帐号下存在同主体的公众号或移动应用,并且该用户已经授权登录过该公众号或移动应用

2月23日后,开发者调用wx.login获取的登录凭证可以直接换取unionID,无需满足以上条件。

回收wx.getUserInfo接口可获取用户个人信息能力

4月28日24时后发布的新版本小程序,开发者调用wx.getUserInfo或<button open-type="getUserInfo"/>将不再弹出弹窗,直接返回匿名的用户个人信息,获取加密后的openID、unionID数据的能力不做调整。

具体变化如下表:

即wx.getUserInfo接口的返回参数不变,但开发者获取的userInfo为匿名信息。




此外,针对scope.userInfo将做如下调整:

  1. 若开发者调用wx.authorize接口请求scope.userInfo授权,用户侧不会触发授权弹框,直接返回授权成功
  2. 若开发者调用wx.getSetting接口请求用户的授权状态,会直接读取到scope.userInfo为true

新增getUserProfile接口

若开发者需要获取用户的个人信息(头像、昵称、性别与地区),可以通过wx.getUserProfile接口进行获取,该接口从基础库2.10.4版本开始支持,该接口只返回用户个人信息,不包含用户身份标识符。该接口中desc属性(声明获取用户个人信息后的用途)后续会展示在弹窗中,请开发者谨慎填写。开发者每次通过该接口获取用户个人信息均需用户确认,请开发者妥善保管用户快速填写的头像昵称,避免重复弹窗。

插件用户信息功能页

插件申请获取用户头像昵称与用户身份标识符仍保留功能页的形式,不作调整。用户在用户信息功能页中授权之后,插件就可以直接调用 wx.login 和 wx.getUserInfo 。

三、最佳实践

调整后,开发者如需获取用户身份标识符只需要调用wx.login接口即可。

开发者若需要在界面中展示用户的头像昵称信息,可以通过<open-data>组件进行渲染,该组件无需用户确认,可以在界面中直接展示。

在部分场景(如社交类小程序)中,开发者需要在获取用户的头像昵称信息,可调用wx.getUserProfile接口,开发者每次通过该接口均需用户确认,请开发者妥善处理调用接口的时机,避免过度弹出弹窗骚扰用户。


微信团队

2021年4月15日


878169浏览
最后一次编辑于  2021-04-15
收藏

562 个评论

  • K
    K
    2021-03-03

    wx.getUserInfo的演变历史:

    第一阶段:wx.getUserInfo随便调,流氓但友好。

    第二阶段: <button open-type="getUserInfo"/>弹窗同意授权后,wx.getUserInfo随便调,克制且合理。

    第三阶段:也就是现阶段,wx.getUserInfo更名为wx.getUserProfile,wx.getUserInfo名存实亡。wx.getUserProfile使用方式更像是第一,第二阶段的结合体,即“点击随便调,每次都弹窗”。

    2021-03-03
    赞同 8
    回复
  • 夏天的橙子🍊
    夏天的橙子🍊
    2021-03-16

    个人觉得微信这个做法是本末倒置了,打个比方:

    一座城(微信),门口有人守城(审核),里面有很多的人(小程序),那放什么人进城,不应该是守城人的事吗?

    现在城里乌烟瘴气,什么人都有,那是谁的责任?

    天天在城里定这个规矩那个规矩,这里搞一下那里搞一下,很高兴?不能从守门抓起?搞事情的人一个都不放进来不行?

    既然什么都人给进来了,那天天搞这个搞那个有啥用?杀人放火的人进了城,你随便定个规矩他就不杀人放火了?

    多弄些守卫,审查严格一点,让进了城的人可以安安心心的玩耍不好?

    2021-03-16
    赞同 7
    回复
  • 骑猫的小毛
    骑猫的小毛
    2021-02-25

    getUserInfo中encryptedData字符里面包含的敏感信息(头像、昵称·城市等字段)解密后,调整前和调整后有区别吗?

    2021-02-25
    赞同 7
    回复 11
    • 微喵网络
      微喵网络
      2021-02-25
      我也关心这个
      2021-02-25
      回复
    • @🦜
      @🦜
      2021-02-25
      估计是有的。不然他们这个改动,有P用。。。。如果真没区别,我只能“呵呵”
      2021-02-25
      回复
    • 权
      2021-02-25
      同问!!!
      2021-02-25
      2
      回复
    • 微喵网络
      微喵网络
      2021-02-25
      希望官方能给个准话
      2021-02-25
      3
      回复
    • 社区技术运营专员-索林
      社区技术运营专员-索林
      2021-02-25
      encryptedData中返回的是匿名的头像昵称
      2021-02-25
      回复
    查看更多(6)
  • Xavier
    Xavier
    2021-02-24

    【wx.login接口获取的登录凭证可直接换取unionID】这个倒是挺好的,不过【wx.getUserInfo接口调整】倒是几个小程序都得维护才行。

    2021-02-24
    赞同 7
    回复
  • 拾忆
    拾忆
    2021-02-24

    wx.getUserProfile 在开发者工具中只有基础库2.15.0才支持。

    

    2021-02-24
    赞同 7
    回复 12
    • 小程序技术专员-sanford
      小程序技术专员-sanford
      2021-02-25
      开发者工具上基础库版本 2.10.4/2.11.2/2.12.3/2.13.2/2.14.1/2.15.0 的有支持 getUserProfile
      2021-02-25
      回复
    • 微喵网络
      微喵网络
      2021-02-25回复小程序技术专员-sanford
      4月13日之后getUserInfo返回的encryptedData还包括头像昵称吗?
      2021-02-25
      回复
    • 拾忆
      拾忆
      2021-02-25回复小程序技术专员-sanford
      好的,谢谢
      2021-02-25
      回复
    • 微焰
      微焰
      2021-02-25回复微喵网络
      包括,但是不是用户本人的了,是匿名的
      2021-02-25
      回复
    • 权
      2021-02-25回复微焰
      已验证?
      2021-02-25
      回复
    查看更多(7)
  • 🌰
    🌰
    2021-03-26

    若开发者调用wx.getSetting接口请求用户的授权状态,会直接读取到scope.userInfo为true

    通过getUserProfile 授权后 调用getSetting并没有返回userInfo授权信息

    是四月13后才会变么

    2021-03-26
    赞同 6
    回复
  • 微喵网络
    微喵网络
    2021-02-25

    现在我就关心4月13日之后getUserInfo返回的encryptedData还包括头像昵称吗?

    2021-02-25
    赞同 6
    回复 9
    查看更多(4)
  • 张艳
    张艳
    2021-03-03

    4月13号之前想要根据该调整进行调整小程序,如何能按照getUserInfo最新的返回的数据进行调试?

    2021-03-03
    赞同 5
    回复 1
    • 社区技术运营专员-索林
      社区技术运营专员-索林
      2021-03-09
      开发者工具会尽快支持这里getUserInfo的改动,但建议后续版本不要再使用getUserInfo
      2021-03-09
      回复
  • 潇湘夜雨2016
    潇湘夜雨2016
    2021-02-25

    一、调整背景

    很多开发者在打开小程序时就通过组件方式唤起getUserInfo弹窗,如果用户点击拒绝,无法使用小程序,这种做法打断了用户正常使用小程序的流程,同时也不利于小程序获取新用户。

    ---------------------------------------------

    这个没太看明白,现有的<button open-type="getUserInfo"/>方式不是用户打开小程序时就唤起getUserInfo弹窗啊,是需要用户点击按钮才弹窗的啊。现有的这种弹窗方式和新的getUserProfile弹窗方式有什么不同呢?

    非要说不同,以前的弹窗只是用户第一次授权时弹一次,之后很长期间内就不弹窗了是吧。但按官方说法,新的getUserProfile弹窗方式是每次都需要用户授权吧?那岂不是弹窗更频繁了呢?

    不太理解,请各位老师指点。


    2021-02-25
    赞同 5
    回复 3
    • yjz.fun
      yjz.fun
      2021-03-01
      同问,这有什么区别呢。 getUserInfo 我们也只弹一次啊
      2021-03-01
      2
      回复
    • Why not?
      Why not?
      2021-03-05
      就是想调整而已,随便找个说辞,不要当真
      2021-03-05
      回复
    • 波粒二象猫🌈
      波粒二象猫🌈
      2021-04-12
      是的   实在没看出来有什么使用上的区别,之前是一个单独的授权页,点击按钮调用getUserInfo,现在只是换成了getUserProfile,也是只需授权一次
      2021-04-12
      回复
  • @🦜
    @🦜
    2021-02-25

    说改就改,你店大欺客,以为小程序就不是店大欺客么。。。保持用户头像、昵称最新肯定是个重要的逻辑,之前一次授权就可以了,现在大部分小程序肯定还会照旧保持这个逻辑,顶多我不是小程序首页就拉起授权,我在一个非落地的重要环节页面拉起不就行了?那大家伙都这么搞咯。坑到最后,还是坑微信用户。羊毛出在羊身上的道理,还是不懂。

    2021-02-25
    赞同 5
    回复

正在加载...

登录 后发表内容