getUserProfile返回获取不到openid和unionid 小程序getUserProfile代替getUserInfo

有点坑,好几个月前的项目了,因改了个正则,上线更新,结果新用户头像和昵称获取不到了。

官方APIhttps://developers.weixin.qq.com/miniprogram/dev/api/open-api/user-info/wx.getUserProfile.html
2021年4月28日24时后发布的小程序新版本,无法通过wx.getUserInfo与获取用户个人信息(头像、昵称、性别与地区),将直接获取匿名数据(包括userInfo与encryptedData中的用户个人信息),获取加密后的openID与unionID数据的能力不做调整。此前发布的小程序版本不受影响,但如果要进行版本更新则需要进行适配。

获取不到openID与unionID啊啊啊啊
原来流程是这样子,
getUserProfile需点击获取

<button class="login-btn"  lang="zh_CN" open-type="getUserProfile" bindtap="authorLogin">
    授权登录
    </button>

基础库版本据说 2.7.0以上,我给调到最高了2.16.1
先调用wx.getUserProfile
接着wx.login
然后用返回的code跟后台换 openid和unionid

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序userInfoopenid是用于标识用户的信息。其中openid是每个用户在小程序中的唯一标识,而userInfo则包含了用户的基本信息,如昵称、头像等。 要获取用户的userInfoopenid,需要进行微信授权。具体步骤如下: 1. 在小程序中引入微信登录模块: ``` var app = getApp(); var util = require('../../utils/util.js'); var api = require('../../config/api.js'); Page({ data: {}, onLoad: function(options) { // 获取用户信息 wx.getSetting({ success: res => { if (res.authSetting['scope.userInfo']) { wx.getUserInfo({ success: res => { // 可以将 res 发送给后台解码出 unionId this.globalData.userInfo = res.userInfo // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回 // 所以此处加入 callback 以防止这种情况 if (this.userInfoReadyCallback) { this.userInfoReadyCallback(res) } } }) } } }) }, }) ``` 2. 在小程序中添加授权按钮: ``` <button type="primary" open-type="getUserInfo" bindgetuserinfo="onGotUserInfo">授权登录</button> ``` 3. 在小程序获取openid: ``` wx.login({ success: res => { // 发送 res.code 到后台换取 openId, sessionKey, unionId wx.request({ url: api.AuthLoginByWeixin, data: { code: res.code }, success: function(res) { if (res.statusCode === 200) { // 将openid存储到本地 wx.setStorageSync('openid', res.data.openid); } else { console.log('请求失败') } } }) } }) ``` 通过以上步骤,就可以获取到用户的userInfoopenid了。其中,openid可以通过wx.getStorageSync('openid')获取
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值