收藏
评论

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

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


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

522 个评论

  • 农民工二代1991
    农民工二代1991
    2021-07-31

     getUserProfile(e) {

        // 推荐使用wx.getUserProfile获取用户信息,开发者每次通过该接口获取用户个人信息均需用户确认

        // 开发者妥善保管用户快速填写的头像昵称,避免重复弹窗

        wx.getUserProfile({

          desc: '用于完善会员资料', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写

          success: (res) => {

            console.log(res)

            wx.checkSession({

              success: (resc) => {

                console.log(resc)

              },

              fail () {

                // session_key 已经失效,需要重新执行登录流程

                wx.login({

                  success:  (login_res) => {

                    console.log(login_res)

                    ///请求自己的服务器了

                    wx.request({

                      url: 'https://sykssjwsx.mynatapp.cc/wx/userinfo',

                      header: { 'Content-Type': 'application/json' },

                      method:'get',  

                      data:  { 

                      code: login_res.code,

                      encryptedData: res.encryptedData,

                      iv: res.iv 

                      },

                      success: res1 => { 

                        console.log(res1.data)

                        wx.hideLoading() 

                        wx.setStorageSync('session', res1.data)

                        wx.showModal({

                          title: '登陆成功',

                          content: '登陆成功',

                          showCancel: false

                        })

                        

                      }

                      }

                  } 

                })

          }

        })

            this.setData({

              userInfo: res.userInfo,

              hasUserInfo: true

            })

            

          }

        })


    2021-07-31
    赞同 1
    回复 1
    • 农民工二代1991
      农民工二代1991
      2021-07-31
      这次发现登陆成功之后清楚缓存,或者手机上移除小程序,都不用再登陆了,因为session_key不失效,第二次打开程序就进不来checkSession的 fail () {}了,就不请求后台了
      2021-07-31
      回复
  • 白小明
    白小明
    2021-04-15

    麻烦兼容下 wx.canIUse('getUserProfile'),现在这个方法在开发者工具上表现正常,但到了真机就出现了问题 😡😡😡

    所以目前只能通过 if 条件判断,但是这种方式不够优雅,坐等微信修复~

    if (wx.getUserProfile) {
      this.setData({ canIUseGetUserProfile: true })
    }
    


    2021-04-15
    赞同 1
    回复
  • 欢乐马
    欢乐马
    2021-04-09

    首页wx.login接口获取的登录凭证可直接换取unionID ”这个需求终于改了,这个问题在2019年9月的登录业务规则改版中就被狠狠的吐槽过,快2年了终于上线了,我能说可喜可贺吗

    接下来我要吐槽了用户信息的修改

    这个功能我们在需要用户授权弹窗基本只会用到一次,后期再用可以直接获取,因为用户信息权限已经开启不会再触发弹窗(一般业务中也基本也不会第二次用到),而现在回收wx.getUserInfo接口可获取用户个人信息能力,改用wx.getUserProfile新的接口是很没有必要的事情,这个问题场景的出现是因为开发者的不规范开发造成的,不是接口有问题,而这个问题不是增加改变一个接口就可以改变,频繁弹窗问题还会继续存在,只有规范开发者使用才是正道,所以我对这个新的用户信息的规则修改评价就是用处不大,对于那些不规范开发现象来说反而加剧了用户弹窗的触发这次调整比不上2019年9月的规则调整,不能解决用户的弹窗骚扰的痛点。所以我给的评价就是差评




    2021-04-09
    赞同 1
    回复
  • 黎小军
    黎小军
    2021-04-08

    先wx.login获取code后再wx.getUserProfile根本没反应,什么报错也没有,把wx.login套入wx.getUserProfile中却可以弹出授权框,但是获取不到UnionId,怎么搞好几天了?

    <button bindtap="getUserProfile">接受</button>
    getUserProfile(e) {
        wx.login({
          success: ress => {
            var code = ress.code; //登录凭证
            console.log(">>>>>>>>>>code:", code)
            wx.getUserProfile({
              desc: '用于获取用户个人信息'// 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
              success: function (detail) {
                wx.request({
                  url: api.getUnionId, //自己的服务接口地址
                  method: 'post',
                  header: {
                    'content-type''application/x-www-form-urlencoded'
                  },
                  data: {
                    encryptedData: detail.encryptedData,
                    iv: detail.iv,
                    code: code,
                  },
                  success: (res) => {
                    console.log("res:", res.data)
                    if (res.data.code == 'C00000') {
                      util.setToken(res.data.msg);
                      util.setStorageSync("userInfo", res.data.obj);
                      wx.redirectTo({
                        url: '/pages/breakpage/breakpage',
                      })
                    }
                  },
                  fail: function () {
                    console.log('系统错误')
                  }
                })
              }
            });
          }
        });
      },
    
    2021-04-08
    赞同 1
    回复
  • momo
    momo
    2021-04-06

    wx.getUserProfile 返回的encryptedData 解密不了 为啥?

    2021-04-06
    赞同 1
    回复 1
    • leo
      leo
      2021-04-16
      我的解密出来没有 openId和unionId ,什么情况?
      2021-04-16
      回复
  • 爱夏天的大西瓜
    爱夏天的大西瓜
    2021-04-06

    4月6号下午,最新版IDE,getSetting接口获取到的用户授权状态里,scope.userInfo还是空的啊,和公告里的不一致!

    2021-04-06
    赞同 1
    回复 2
    • 古?
      古?
      2021-04-08
      4月8号 也没获取到
      2021-04-08
      回复
    • 盖子
      盖子
      2021-04-15
      4月15号 scope.userinfo已经能拿到true了,但是已经全部改完了,根据后端接口来判断是否授权,之前所有getsetting的逻辑全部删掉了
      2021-04-15
      1
      回复
  • 日行千里孙膑
    日行千里孙膑
    2021-04-06

    一点人事都不干有什么用

    2021-04-06
    赞同 1
    回复
  •    
       
    2021-04-06

    不是说13号改吗,怎么现在就已经获取不到用户信息了

    2021-04-06
    赞同 1
    回复
  • WebMike🦁
    WebMike🦁
    2021-04-06

    我用了最新的机制了,但是发现现在从微信PC客户端打开小程序后,点击登录授权没反应了,请问怎么解决?

    2021-04-06
    赞同 1
    回复
  • 阿杜
    阿杜
    2021-04-05

    你们能不能一天到晚干点正事儿,一个接口改来改去,今天兼容button open-type, 明天兼容getUserProfile;后天还要兼容啥?不能一开始就设计好一点儿吗,这个太操蛋了,fuck

    2021-04-05
    赞同 1
    回复

正在加载...

登录 后发表内容