加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

微信小程序getUserInfo授权问题的解决办法

发布时间:2020-12-14 19:54:20 所属栏目:资源 来源:网络整理
导读:惠民小程序小编了解到,微信小程序成为当下热门话题,下面从多个方面来谈谈 微信小程序getUserInfo授权问题的解决办法 。 最新消息, 近日, 微信官方对小程序组件进行两个调整,给用户提供更自主的选择权。 1 打开其他小程序组件上线,用户点击后就可以直接

惠民小程序小编了解到,微信小程序成为当下热门话题,下面从多个方面来谈谈微信小程序getUserInfo授权问题的解决办法

最新消息, 近日, 微信官方对小程序组件进行两个调整,给用户提供更自主的选择权。 1 打开其他小程序组件上线,用户点击后就可以直接跳转到其他小程序了。 2 新增打开小程序设置页组件,用户点击后可以进入设置页管理自己的各项授权信息。 ■开发者

我们在首次进入小程序时,会通过getUserInfo调起用户授权的弹窗,但是根据微信小程序,最新更新解释,开发工具,体验版本将不再支持这个授权方式

而是通过button组件让用户自主去点击已完成授权目的(这个对开发者来说真的是很蛋疼)那我们怎么以最小的代价,来完成授权逻辑的升级呢?

这里根据官方文档给出我的解决方案

设置一个用户授权登录的过渡页面,用户首次,进入小程序时,通过 请升级微信版本 让用户自己去点击这个授权登录的按钮,然后再去进行后续的业务逻辑

延伸

如果用户恰好在某个页面登录态失效时,统一让其跳转到登录界面,点击授权登录成功,返回到之前的页面

下面是具体代码

1 App.js 2 App({ 3 onLaunch: function () {},4 onShow: function () {},5 .....,6 toLogin: function () { 7 // 前往授权登录界面 8 wx.navigateTo({ 9 url: '/pages/toLogin/toLogin',10 })11 },12 ready: function () {13 return Promise((resolve,reject) => {14 const userkey = wx.getStorageSync('userkey')15 const userId = wx.getStorageSync('userId')16 const sessionData = wx.getStorageSync('sessionData')17 // 检查用户是否具有登陆态18 if (!userkey || !userId || !sessionData) {19 // 如果未登录就前往登录界面20 this.toLogin()21 } else {22 // 如果有就只要更改一下Promise,以继续执行后续操作23 resolve()24 }25 })26 }27 })

1 somePage.js 2 var app = getApp() 3 const someServces = require('统一接口处理文件') 4 Page({ 5 data: {},6 onLoad: function (){},7 onShow: function (){},8 ......,9 getSomeData () {10 // 这里我们每次调用接口时,都要先去调用app.js中的ready方法11 // 在app中ready会返回一个promise对象,只有其返回的状态时resolved状态时才会触发.then()方法12 app.ready().then(() => {13 // 获取服务端数据14 })15 }16 })

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读