收藏
评论

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

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


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

573 个评论

  • 沧海的雨季
    沧海的雨季
    2021-03-10

    请问一下之后可以直接在进入小程序就获取用户头像昵称吗?(之前不是不能直接进来弹窗么)

    我们现在这个小程序需要进来就获取用户昵称和头像来确认用户身份,然后根据这个来展示不同的页面..

    getUserProfile不是需要通过按钮才能触发么, 我通过showModal确定触发getUserProfile,获取身份, 展示不同的页面。。 请问这样可以吗?

    2021-03-10
    赞同
    回复
  • Освободи.   сердце
    Освободи. сердце
    2021-03-10

    我就想知道还需要给基础库版本做兼容么?

    2021-03-10
    赞同
    回复
  • 大千一尘
    大千一尘
    2021-03-10

    多点个按钮,多弹个框,多提醒一下用户,咋啦~~~~咋啦~~~~咋啦~~~~你们难道还想造反不成!

    2021-03-10
    赞同
    回复
  • 神经蛙
    神经蛙
    2021-03-10

    这个更新是真香

    2021-03-10
    赞同
    回复
  • shystar
    shystar
    2021-03-09

    4月13日之前已经发布的线上小程序,如果不更新,getUserInfo接口还是正常返回数据吗?不会影响已经在线上的小程序吧?

    是不是只是4月13日之后发布的小程序才会返回匿名数据?

    2021-03-09
    赞同
    回复
  • Charles
    Charles
    2021-03-09

    改的有些烦了,登录+用户体系 我做成插件的形式,绑定了基础业务逻辑的。调整一次,我改一次。调整的也太频繁了些,一年一调整,真是够了。

    2021-03-09
    赞同
    回复
  • 贺振军
    贺振军
    2021-03-09

    这意思是4月13后发布的小程序,解密后的用户信息也是看不到用户头像和昵称?

    2021-03-09
    赞同
    回复 2
    • 成意泐
      成意泐
      2021-03-09
      是的
      2021-03-09
      回复
    • 贺振军
      贺振军
      2021-03-10
      现在开发工具调用getUserInfo获取到的数据还是明文数据,只能等能4.13号之前才能获取到匿名数据?
      2021-03-10
      回复
  • 修半桶电脑
    修半桶电脑
    2021-03-09

    我就是想过滤那些不愿意授权的用户,你不授权,就是对我的小程序没兴趣,我也不需要你,就此别过,我为毛还要浪费空间保存你的到访记录。。。

    2021-03-09
    赞同
    回复 1
    • 修半桶电脑
      修半桶电脑
      2021-03-09
      补充一句,你加getUserProfile就加,特么改我getUserInfo的功能,我这周又要加班
      2021-03-09
      回复
  • 郭成成 Richie
    郭成成 Richie
    2021-03-09

    2021.4.13日后,怎么兼容2.10.4以下的低版本?

    1. 2021年4月13日无法通过wx.getUserInfo和组件获取用户个人信息
    2. wx.getUserProfile 在基础库2.10.4开始支持

    问题2021.4.13日之后,基础库在2.10.4以下的怎么获取用户信息?

    根据微信开发中工具中的基础库版本使用率,粗略加了以下,基础库在2.10.4以下的还有0.79%的占比,对于百万用户的小程序,这个占比有点大,还是说这个数据有问题?


    另外,官方文档也说了要对getUserProfile做兼容处理,老路(wx.getUserInfo和组件)已被弃用,那么怎么兼容呢?

    2021-03-09
    赞同
    回复 4
    • 成意泐
      成意泐
      2021-03-09
      近期会将getUserProfile再向下兼容至2.6.6版本,对于低版本的用户如果有获取头像昵称的诉求,可以要求用户手动上传
      2021-03-09
      回复
    • worm
      worm
      2021-03-11回复成意泐
      不行啊  我们是出行服务的小程序 得兼容到1.9.9.0,你们这样搞我们50%的新用户都拿不到信息了
      2021-03-11
      回复
    • จุ๊บ孤狼
      จุ๊บ孤狼
      2021-03-28回复成意泐
      近期是啥时候啊,这次的公告出的不清不楚,还不向下兼容,可以把兼容方案描述详细一点吗,什么能用什么不能用,具体的可用日期明示一下,现在基本靠猜啊
      2021-03-28
      回复
    • 怦然心动
      怦然心动
      2021-03-30回复成意泐
      您好,请问13号上线最大可能兼容到那个版本?可以给一个稳妥的版本吗
      2021-03-30
      回复
  • 晴天
    晴天
    2021-03-09

    不愧是你呀,腾讯

    2021-03-09
    赞同
    回复

正在加载...

登录 后发表内容