收藏
评论

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

公告更新时间: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日


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

573 个评论

  • Listen
    Listen
    2021-02-25

    重要的事情问3遍:

    影响 button open-type="getUserInfo" 吗?

    影响 button open-type="getUserInfo" 吗?

    影响 button open-type="getUserInfo" 吗?

    2021-02-25
    赞同 1
    回复 2
    • 成意泐
      成意泐
      发表于移动端
      2021-02-25
      同样需要调整,稍后会在调整后的公告中说明
      2021-02-25
      回复
    • Rick
      Rick
      2021-03-05回复成意泐
      请问,对网站上的SSO有影响吗,很急,求解答, 谢谢
      2021-03-05
      回复
  • 一一
    一一
    2021-02-25

    要怎么调试呢,真机上还是原来的逻辑啊

    2021-02-25
    赞同 1
    回复
  • 为什么不是我?
    为什么不是我?
    2021-02-25

    小程序和公众号进行了关联,没有绑定到开放平台,jscode2session可以获取到unionID吗?今天测试获取不到,是要重新发布小程序的版本吗?

    2021-02-25
    赞同 1
    回复 9
    • 为什么不是我?
      为什么不是我?
      2021-02-25
      今天是2021-02-25
      2021-02-25
      回复
    • 人生一张西
      人生一张西
      2021-02-25
      wx.login 你可以拿到unionID吗,为什么我这里还是只有openId
      2021-02-25
      回复
    • :P
      :P
      2021-02-25
      不绑定开放平台怎么拿unionid,即使给你拿到了 也会不一致吧
      2021-02-25
      回复
    • 猛男陈阔
      猛男陈阔
      2021-02-26回复:P
      这句话说的很清楚了吧
      2021-02-26
      回复
    • 苏晓光
      苏晓光
      2021-02-26
      我也还没有看到unionId
      2021-02-26
      回复
    查看更多(4)
  • ❤️
    ❤️
    2021-02-25

    getUserProfile获取的数据是加密的么?

    2021-02-25
    赞同 1
    回复 3
    • 微喵网络
      微喵网络
      2021-02-25
      自己试一下就知道了,明文的
      2021-02-25
      回复
    • 贺振军
      贺振军
      2021-03-10
      明文数据
      2021-03-10
      回复
    • 亦云
      亦云
      2021-03-23回复贺振军
      如何保证数据的合法性 , 图片 和昵称    涉黄   敏感词汇
      2021-03-23
      1
      回复
  • 猛男陈阔
    猛男陈阔
    2021-02-25

    app.js onlanch初始化的时候调用wx.login获取openId、及unionID做登录标识

    用户头像、昵称这些数据通过<open-data>进行展示

    2021-02-25
    赞同 1
    回复 4
    • 猛男陈阔
      猛男陈阔
      2021-02-25
      如果需要存储用户头像这些信息,通过getUserProfile去获取userInfo
      2021-02-25
      回复
    • 贺振军
      贺振军
      2021-03-10
      通过open-data进行展示是不影响的,但如果你要保存这些信息就不行了
      2021-03-10
      回复
    • 猛男陈阔
      猛男陈阔
      2021-03-11回复贺振军
      是的 你可以通过api获取到加密数据,异步调用给后端解密去存储
      2021-03-11
      回复
    • 海蓝色贝壳🌸 🌻
      海蓝色贝壳🌸 🌻
      2021-03-12回复猛男陈阔
      你获取的加密信息是通过什么api获取的?
      2021-03-12
      回复
  • 大兵
    大兵
    2021-02-25

    讲道理,这个调整感觉并没有解决“调整背景”中的问题。

    2021-02-25
    赞同 1
    回复 1
    • 王建
      王建
      2021-02-25
      解决了不需要昵称头像只需要 unionId 的场景。对于需要存储昵称头像的小程序,弹窗只会更多,不会减少。
      2021-02-25
      回复
  • 张老师
    张老师
    发表于小程序端
    2021-02-25
    还好,我的小程序只是展示用户信息,逻辑不用大改动嘻嘻
    2021-02-25
    赞同 1
    回复
  • 2021-02-25

    微信就是牛🐂

    2021-02-25
    赞同 1
    回复
  • 有棱角的胖子
    有棱角的胖子
    2021-02-25

    测试测试

    2021-02-25
    赞同 1
    回复
  • 2023-12-04

    就这么一个通用功能 被改的云里雾里 👍

    2023-12-04
    赞同
    回复

正在加载...

登录 后发表内容