微信小程序之授权登录的实现(附完整源码)

news/2024/7/15 14:44:54

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

前言:由于微信官方修改了 getUserInfo 接口,所以现在无法实现一进入微信小程序就弹出授权窗口,只能通过 button 去触

发。官方连接:点击打开链接

1.实现思路

自己写一个微信授权登录页面让用户实现点击的功能,也就是实现了通过 button 组件去触发 getUserInof 接口。在用户进入微

信小程序的时候,判断用户是否授权了,如果没有授权的话就显示下面“界面简介”的第一个图,让用户去执行授权的操作。如

果已经授权了,则直接跳过这个页面,进入首页。

2.界面简介

3.源码

login.wxml

<view wx:if="{{canIUse}}"><view class='header'><image src='/images/wx_login.png'></image></view><view class='content'><view>申请获取以下权限</view><text>获得你的公开信息(昵称,头像等)</text></view><button class='bottom' type='primary' open-type="getUserInfo" lang="zh_CN" bindgetuserinfo="bindGetUserInfo">授权登录</button>
</view><view wx:else>请升级微信版本</view>

login.wcss

.header {margin: 90rpx 0 90rpx 50rpx;border-bottom: 1px solid #ccc;text-align: center;width: 650rpx;height: 300rpx;line-height: 450rpx;
}.header image {width: 200rpx;height: 200rpx;
}.content {margin-left: 50rpx;margin-bottom: 90rpx;
}.content text {display: block;color: #9d9d9d;margin-top: 40rpx;
}.bottom {border-radius: 80rpx;margin: 70rpx 50rpx;font-size: 35rpx;
}

login.json

{"navigationBarTitleText": "授权登录"
}

login.js

代码的 wx.request 是我项目与后台的一些交互,可直接删除掉。

需要修改的地方:

记得自己补上 wx.switchTab 接口中的 url 属性,这是授权成功后跳转的页面路径,由于我的首页是 tarBar 页面,所以这里用 

wx.switchTab ,如果不是 tarBar 页面的话,可以用 wx.navigateTo 和 wx.redirecTo 去跳转页面。 

Page({data: {//判断小程序的API,回调,参数,组件等是否在当前版本可用。canIUse: wx.canIUse('button.open-type.getUserInfo')},onLoad: function () {var that = this;// 查看是否授权wx.getSetting({success: function (res) {if (res.authSetting['scope.userInfo']) {wx.getUserInfo({success: function (res) {//从数据库获取用户信息that.queryUsreInfo();//用户已经授权过wx.switchTab({url: ''})}});}}})},bindGetUserInfo: function (e) {if (e.detail.userInfo) {//用户按了允许授权按钮var that = this;//插入登录的用户的相关信息到数据库wx.request({url: getApp().globalData.urlPath + 'hstc_interface/insert_user',data: {openid: getApp().globalData.openid,nickName: e.detail.userInfo.nickName,avatarUrl: e.detail.userInfo.avatarUrl,province:e.detail.userInfo.province,city: e.detail.userInfo.city},header: {'content-type': 'application/json'},success: function (res) {//从数据库获取用户信息that.queryUsreInfo();console.log("插入小程序登录用户信息成功!");}});//授权成功后,跳转进入小程序首页wx.switchTab({url: ''  })} else {//用户按了拒绝按钮wx.showModal({title:'警告',content:'您点击了拒绝授权,将无法进入小程序,请授权之后再进入!!!',showCancel:false,confirmText:'返回授权',success:function(res){if (res.confirm) {console.log('用户点击了“返回授权”')} }})}},//获取用户信息接口queryUsreInfo: function () {wx.request({url: getApp().globalData.urlPath + 'hstc_interface/queryByOpenid',data: {openid: getApp().globalData.openid},header: {'content-type': 'application/json'},success: function (res) {console.log(res.data);getApp().globalData.userInfo = res.data;}});},})

 

亲,如果您感觉本文有用,请点个赞再走吧!!(>‿◠)✌

转载于:https://my.oschina.net/ZhenyuanLiu/blog/1924867


http://lihuaxi.xjx100.cn/news/236459.html

相关文章

32位java 最大内存_【答疑系列】为什么32位系统只支持最大4G内存?

这个问题一直都有同学问到&#xff0c;算是提问次数最多的问题之一了。32位是什么现在主流的操作系统都是64位的&#xff0c;早期存在32位操作系统&#xff0c;相信大家也都有所听闻&#xff0c;其实&#xff0c;在更早之前&#xff0c;还有16位、8位的&#xff0c;这里就不展开…

什么是POM maven

POM是项目对象模型(Project Object Model)的缩写&#xff0c;下面援引一下百度百科中对于POM的解释 定义 Maven是以项目为中心的设计。POM是Maven对一个单一项目的描述。没有POM的话&#xff0c;Maven是毫无用处的——POM是Maven的核心。是POM实现的并驱动了这种以模型来描述的…

9.8.6恢复系统数据库

系统数据库和用户数据库一样容易发生故障&#xff0c;所以确保它们得到足够的保护十分重 要。一般来说&#xff0c;恢复系统数据库时有两种选择。可以从备份还原&#xff0c;或者从头重建它们。我 强烈推荐备份还原方法&#xff0c;因为从头重建意味着有人量的工作要做。由于系…

QTP的那些事---页面弹出框的处理,页面等待加载的处理

处理方法&#xff1a;先判断父类对象是否存在&#xff0c;如果存在&#xff0c;判断相关的static文本对象是否存在&#xff0c;如果存在&#xff0c;则点击弹出框中的按钮即可&#xff1b; 例如如下的代码&#xff1a; 设置循环判断dialog对象是否存在&#xff0c;如果存在&…

java gps时间转换工具_java 时间戳和时间互转工具 和 时间偏移量计算

时间互转代码片段&#xff1a;* 时间戳 转 时间 ** param beginDate* return* see [类、类#方法、类#成员]*/public static String timeStampToTime(String beginDate){SimpleDateFormat sdf new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");Date date new Date(Long…

Docker镜像使用

当运行容器时&#xff0c;使用的镜像如果在本地中不存在&#xff0c;docker 就会自动从 docker 镜像仓库中下载&#xff0c;默认是从 Docker Hub 公共镜像源下载。 下面我们来学习&#xff1a; 1、管理和使用本地 Docker 主机镜像2、创建镜像列出镜像列表 我们可以使用 docker …

关闭Windows 8的metro UI的方法汇总

http://www.ssdax.com/570.html 上面就是windows8新出现的Metro UI&#xff0c;点击开始菜单就会出现&#xff0c;取代了windows长久以来的开始菜单&#xff0c;有了非常大的突破 不过我发现很多人都在找怎么关闭windows8 的Metro UI&#xff0c;下面介绍两个如何关闭Metro的方…

modifiers在JAVA中_Java Modifier.classModifiers方法代碼示例

import java.lang.reflect.Modifier; //導入方法依賴的package包/類/*** Returns a string describing this {code Class}, including* information about modifiers and type parameters.** The string is formatted as a list of type modifiers, if any,* followed by the k…