微信小程序获取用户信息“授权失败”场景的处理

转载 2018年01月19日 11:29:10

很多的时候我们在处理小程序功能的时候需要用户获取用户信息,但是呢为了信息安全,用户不授权导致授权失败场景;但是小程序第二次不在启动授权信息弹层,为了用户体验,可以用以下方式处理:

  1. function isEmptyObject(e) {
  2. //对象是否为空;判断是否是第一次授权,非第一次授权且授权失败则进行提醒
  3. var t;
  4. for (t in e)
  5. return !1;
  6. return !0
  7. }
  1. function checkSettingStatu(cb) {
  2. //授权处理
  3. var that = this;
  4. // 判断是否是第一次授权,非第一次授权且授权失败则进行提醒
  5. wx.getSetting({
  6. success: function success(res) {
  7. var authSetting = res.authSetting;
  8. if (isEmptyObject(authSetting)) {
  9. // console.log('首次授权');
  10. } else {
  11. // console.log('不是第一次授权', authSetting);
  12. // 没有授权的提醒
  13. if (authSetting['scope.userInfo'] === false) {
  14. wx.showModal({
  15. title: '用户未授权',
  16. content: '如需正常使用此小程序功能,请您按确定并在设置页面授权用户信息',
  17. showCancel: false,
  18. success: function (res) {
  19. // 此处为了用于 Android 系统区分点击蒙层关闭还是点击取消按钮关闭省去了res.confirm,res.cancel判断
  20. // 点击蒙层同样触发开启设置
  21. wx.openSetting({
  22. success: function success(res) {
  23. if (res.authSetting['scope.userInfo'] === false) {
  24. checkSettingStatu(cb);
  25. } else {
  26. userinfor();
  27. }
  28. }
  29. });
  30. }
  31. })
  32. }
  33. }
  34. }
  35. });
  36. }
  1. function userinfor(){
  2. //获取用户信息
  3. wx.login({
  4. success: function (res) {
  5. var code = res.code;
  6. if (res.code) {
  7. wx.getUserInfo({
  8. fail: function (res) {
  9. checkSettingStatu();
  10. },
  11. success: function (data) {
  12. var encryptedData = data.encryptedData;
  13. var iv = data.iv;
  14. wx.request({
  15. url: 'XXXX',
  16. data: {
  17. "json": JSON.stringify({
  18. "type": "small_wechat_new",
  19. "code": code,
  20. "encryptedData": encryptedData,
  21. "iv": iv
  22. })
  23. },
  24. method: 'POST',
  25. header: {
  26. 'content-type': 'application/x-www-form-urlencoded'
  27. },
  28. success: function (res) {
  29. //wx.setStorageSync('user_id', res.data.data.user_id);
  30. //wx.setStorageSync('token', res.data.data.token);
  31. //wx.setStorageSync('avatar', res.data.data.avatar);
  32. //wx.setStorageSync('nickname', res.data.data.nickname);
  33. }
  34. })
  35. }
  36. })
  37. }
  38. }
  39. })
  40. }
  41. module.exports = {
  42. checkSettingStatu: checkSettingStatu,
  43. userinfor: userinfor
  44. }

【总结】微信小程序 - 用户授权时被拒绝的解决办法(授权失败场景处理)

因为当下在做的小程序功能必须获取用户信息才能操作,所以在index页面就弹用户授权了,此处参考了【这篇文章】。文章中提到一点开小程序就弹用户授权多少会对用户造成一定的心里压力,所以大家还是按照自己的需...
  • sinat_22014829
  • sinat_22014829
  • 2017年08月30日 18:16
  • 4191

微信小程序-“授权失败”场景的优雅处理

微信小程序中提供了相关API 让开发者能获取到微信用户的相关信息,在首次去获取的时候会展示一个用户是否同意授权的对话框。发现有不少线上的小程序都没有处理好用户“拒绝授权”导致的“授权失败”场景。一个观...
  • wtdask
  • wtdask
  • 2017年12月21日 16:00
  • 631

微信小程序开发(6)---用户拒绝授权,重新调起授权

用户拒绝授权,重新调起授权
  • qq_28189091
  • qq_28189091
  • 2017年07月19日 17:00
  • 4368

微信小程序处理用户拒绝授权情况及微信登录,登录保存等系列解决方案

在微信小程序开发时,当我们调用API  wx.getUserInfo(OBJECT) 时,需要用户授权。但如果用户拒绝授权,我们如何兼容用户拒绝授权状态,拥有更好的用户体验呢? 先看看这个接口的官方...
  • zgmu
  • zgmu
  • 2017年07月18日 18:16
  • 7617

小程序没有授权时的处理方法

在做小程序开发的时候,我们经常会需要获取用户的一些权限。比如获取用户信息用于直接登录,获取地理位置用于定位等。但要是用户拒绝授权了,该怎么处理呢?...
  • a49220824
  • a49220824
  • 2017年06月24日 11:30
  • 7781

微信小程序如何再次获取用户授权

现在在做一个小程序有地图的功能,通过点击按钮打开地图。调用wx.getlocation()这个接口是需要用户的授权。如果他授权了,返回一个success当然最好啦,就什么问题都没有了。如果他点了取消,...
  • hanzhaoshuai
  • hanzhaoshuai
  • 2017年05月21日 21:36
  • 13360

小程序登录&授权&获取用户信息

一  登录 时序图如下: wx.login() 获取js_code 示例代码: App({   onLaunch: function() {     wx.login...
  • qq_33616529
  • qq_33616529
  • 2018年01月16日 22:48
  • 704

微信小程序首页数据初始化失败的解决方法

用户首次后再次进入小程序时,我们通常需要通过获取用户openid或unionid用作唯一标示与后台进行数据交流,初始化用户信息。当我们通过第三方服务器跟微信建立请求时,微信需要用户确认是否公开信息。如...
  • zhilonng
  • zhilonng
  • 2017年01月08日 11:10
  • 1632

微信开发获取出错信息,进行debug错误调试-微信开发教程8

在进行微信公众号开发时, 不可避免的会遇到程序出错, 但是微信开发跟本地开发不同, 本地开发时, 你可以通过调整错误级别来显示错误提示, 方便你调试程序, 但是微信开发时是...
  • towtotow
  • towtotow
  • 2017年09月20日 10:10
  • 302

微信小程序request请求session失败

这两天要被request请求搞死了,一直从服务器那边请求不到session,后面看来网上的解决办法才知道少了session_id,下面是我的解决方式:小程序端://得到thridsession和ses...
  • qq_37996815
  • qq_37996815
  • 2017年12月29日 15:42
  • 250
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:微信小程序获取用户信息“授权失败”场景的处理
举报原因:
原因补充:

(最多只允许输入30个字)