【微信小程序】用户首次进入小程序拒绝授权,如何再次调用授权页面,获取用户信息userInfo
前言:微信小程序的app.js里面,最少有2个接口,一个wx.login;一个是wx.getUserInfo; 前者得到腾讯给我们的微信用户唯一的code,通过code获取openid,这个不需要用户授权,我们肯定能得到;
但是,后者是需要用户授权,我们才能通过腾讯得到用户的其他信息,比如nickname、avatarUrl、encryptedData、iv等,如果你只需要openid,下面的代码你可以不用看了,下面重点讲解如何
多次调用wx.getUserInfo或者app.getUserInfo接口获取用户的nickname、avatarUrl等信息。
3、比如说,我们可以在小程序>个人中心页面,用户点击【我】的时候,在onload或者onReady时候,调用下面这个方法,执行:再次确认是否授权->用户授权->获取userInfo(包含:nickname、avatarUrl等)->自定义操作(比如注册、或者 将获得的用户nickname和avatarUrl 现实在页面上)->其他操作
4、方法代码和使用Demo:其中【私人订制】这里是自己进行php后台注册的一个过程,你们根据自己需求进行开发
var app = getApp() var loginStatus = true;//默认授权成功
var getPromission = function (that) {
if (!loginStatus) {
// 显示提示弹窗
wx.showModal({
title: '温馨提示',
content: '您确定不授权[西厢房乡居生活]小程序吗?部分功能可能会收到影响',
success: function (res) {
if (res.confirm) {
console.info("1授权失败返回数据");
wx.showToast({
title: '授权失败,您可能有部分功能无法使用',
icon: 'success',
duration: 5000
})
} else if (res.cancel) {
wx.openSetting({
success: function (data) {
if (data) {
if (data.authSetting["scope.userInfo"] == true) {
loginStatus = true;
wx.getUserInfo({
withCredentials: false,
success: function (data) {
console.info("1成功获取用户返回数据");
that.setData({
userInfo: data.userInfo,
})
console.info(data.userInfo);
// --------- 4、发起后台注册请求(私人定制) ------------------
wx.request({
url: 'https://m.*****.com/index.php/Home/Xiaoxxf/register',
data: {
'nickName': data.userInfo.nickName,
'openid': wx.getStorageSync('openid')
},
header: {
"Content-Type": "application/x-www-form-urlencoded"
},
method: 'POST',
dataType: 'JSON',
success: function (res) {
console.log(0);
console.log(res.data);
},
fail: function (res) {
console.log(1);
},
complete: function (res) {
console.log(2);
},
})
app.globalData.userInfo = that.data.userInfo; //用户所有信息放在globalData
wx.setStorageSync('userInfo', that.data.userInfo);//存储userInfo
},
fail: function () {
console.info("2授权失败返回数据");
wx.showToast({
title: '授权失败,您可能有部分功能无法使用',
icon: 'success',
duration: 5000
})
} });
}
}
},
fail: function () {
console.info("设置失败返回数据");
} })
}
}
})
} else {
wx.login({
success: function (res) {
if (res.code) {
wx.getUserInfo({
withCredentials: false,
success: function (data) {
console.info("2成功获取用户返回数据");
that.setData({
userInfo: data.userInfo,
})
},
fail: function () {
console.info("3授权失败返回数据");
loginStatus = false;
// 显示提示弹窗
wx.showModal({
title: '温馨提示',
content: '您确定不授权[西厢房乡居生活]小程序吗?部分功能可能会收到影响',
success: function (res) {
if (res.confirm) {
console.info("4授权失败返回数据");
wx.showToast({
title: '授权失败,您可能有部分功能无法使用',
icon: 'success',
duration: 5000
})
} else if (res.cancel) {
wx.openSetting({
success: function (data) {
if (data) {
if (data.authSetting["scope.userInfo"] == true) {
loginStatus = true;
wx.getUserInfo({
withCredentials: false,
success: function (data) {
console.info("3成功获取用户返回数据");
console.info(data.userInfo);
//更新数据
that.setData({
userInfo: data.userInfo,
})
// --------- 4、发起后台注册请求(私人定制) ------------------
wx.request({
url: 'https://m.****.com/index.php/Home/Xiaoxxf/register',
data: {
'nickName': data.userInfo.nickName,
'openid': wx.getStorageSync('openid')
},
header: {
"Content-Type": "application/x-www-form-urlencoded"
},
method: 'POST',
dataType: 'JSON',
success: function (res) {
console.log(0);
console.log(res.data);
},
fail: function (res) {
console.log(1);
},
complete: function (res) {
console.log(2);
},
})
app.globalData.userInfo = that.data.userInfo; //用户所有信息放在globalData
wx.setStorageSync('userInfo', that.data.userInfo);//存储userInfo
},
fail: function () {
console.info("5授权失败返回数据");
wx.showToast({
title: '授权失败,您可能有部分功能无法使用',
icon: 'success',
duration: 5000
})
} });
}
}
},
fail: function () {
console.info("设置失败返回数据");
} });
}
}
});
} });
}
},
fail: function () {
console.info("登录失败返回数据");
} });
}
} Page({
data: { }, onLoad: function () { },
onShow:function(){
var that = this
//调用应用实例的方法获取全局数据
app.getUserInfo(function (userInfo) {
console.log(userInfo);
if (userInfo == null) {
console.log('ccc');
getPromission(that);
} })
}
})
重点:getPromission放置的位置很重要,到底是放在onload还是onshow呢?其实看情况区分的。
Answer:1)放在onshow页面:如果你是在tarBar页面(主页面),请将getPromission放在onshow方法里面,因为进入小程序的主页面总共只加载一次onload和onReady,而onshow却每次都加载,实际环境中,我们肯定是希望未授权的用户每次进入该页面都询问一次是否授权。
2)放在onload页面:如果你是在内置页(各种详情页、非tarbar页),请将getPromission放在onload页面,因为每次进入详情页都会加载一次onload。
6、代码效果图:

【微信小程序】用户首次进入小程序拒绝授权,如何再次调用授权页面,获取用户信息userInfo的更多相关文章
- 微信测试号开发之九 微信网页授权:页面获取用户openid
原文链接:https://blog.csdn.net/qq_37936542/article/details/78981369 一:配置接口 注意:这里填写的是域名(是一个字符串),而不是URL,因此 ...
- Request 获取根据页面获取用户输入判断登陆成功或者失败
import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.serv ...
- Web页面获取用户控件页面中服务器控件的值
用户控件页面后台: public string P_Name{get { return txt_P_name.Value; }set { txt_P_name.Value = value; }} We ...
- 微信公众平台开发实战Java版之如何网页授权获取用户基本信息
第一部分:微信授权获取基本信息的介绍 我们首先来看看官方的文档怎么说: 如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑. 关于网页授权回调域 ...
- 微信网页授权,获取微信code,获取access_tocken,获取用户信息
微信开发中,经常有这样的需求:获得用户头像.绑定微信号给用户发信息.. 那么实现这些的前提就是授权! 1.配置安全回调域名: 在微信公众号请求用户网页授权之前,开发者需要先到公众平台官网中的“开发 ...
- 第八篇 :微信公众平台开发实战Java版之如何网页授权获取用户基本信息
第一部分:微信授权获取基本信息的介绍 我们首先来看看官方的文档怎么说: 如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑. 关于网页授权回调域 ...
- 微信开发第5章 通过accesstoken获取用户基本信息并修改用户备注
在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的.对于不同公众号,同一用户的openid不同).公众号可通过本接口来根据Op ...
- 微信 OAuth2 网页授权获取用户信息
文档:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html !!! 微信跟用户没有关系类接口采用了OAUTH2 [ ...
- Java微信公众平台开发(十六)--微信网页授权(OAuth2.0授权)获取用户基本信息
转自:http://www.cuiyongzhi.com/post/78.html 好长时间没有写文章了,主要是最近的工作和生活上的事情比较多而且繁琐,其实到现在我依然还是感觉有些迷茫,最后还是决定静 ...
随机推荐
- [Android Pro] Swift 3.0多线程
本文只介绍Grand Central Dispath(GCD) 中央调度 个人认为一个GCD就够用了,可能是改版或是其他的在找之前写的多线程方法时发现不能用了,看文档之后发现改了,现在看上去更加简单易 ...
- 【XJOI】【NOI考前模拟赛7】
DP+卡常数+高精度/ 计算几何+二分+判区间交/ 凸包 首先感谢徐老师的慷慨,让蒟蒻有幸膜拜了学军的神题.祝NOI2015圆满成功 同时膜拜碾压了蒟蒻的众神QAQ 填填填 我的DP比较逗比……( ...
- C++获得本机所有网卡的IP和MAC地址信息
一台机器上可能不只有一个网卡,但每一个网卡只有一个MAC地址,而每一个网卡可能配置有多个IP地址:如平常的笔记本电脑中,就会有无线网卡和有线网卡(网线接口)两种:因此,如果要获得本机所有网卡的IP和M ...
- VUE router-view 页面布局 (嵌套路由+命名视图)
嵌套路由 实际生活中的应用界面,通常由多层嵌套的组件组合而成.同样地,URL 中各段动态路径也按某种结构对应嵌套的各层组件,例如: /user/foo/profile /user/foo/posts ...
- IDEA热部署基于maven的web项目
第一步:首先先创建web项目 按照向导一步一步完成项目创建,我创建的示例项目为hotdeploddemo 第二步:设置项目的web资源 下图中的路径要修改正确,指向src/ma ...
- Java中浮点类型的精度问题 double float
要说清楚Java浮点数的取值范围与其精度,必须先了解浮点数的表示方法与浮点数的结构组成.因为机器只认识01,你想表示小数,你要机器认识小数点这个东西,必须采用某种方法.比如,简单点的,float四个字 ...
- java 解析 XML实例
package com.hseact.fecp.servlet; import java.io.IOException; import javax.xml.parsers.DocumentBuilde ...
- vue当前路由跳转初步研究
一样闲话少说,直接上问题,如图: 也是消息面板,没想到一个小小的消息面板,碰到这么多坑,惆怅. 就是如果当前路由和跳转路由不一样时,正常跳转没有任何问题.但是如果一样时,就不会跳转了,用了很多方法,比 ...
- 模态框在IE下的问题,即position:fixed在IE下不兼容的处理方式
项目中遇到的问题,模态框在IE下总出现如图所示双层遮罩框,经排查发现是由于bootstrap里写的modal的样式里position:fixed不兼容IE的原因,导致铺不满整个窗口. 解决方案:在项目 ...
- IOS Xib使用——为控制器添加Xib文件
Xib文件是一个轻量级的用来描述局部界面的文件,它与StoryBoard类似,都是使用Interface Bulider工具进行编辑.但是StoryBoard是重量级的,它是用来描述整个软件的多个界面 ...