首页 > 编程 > JavaScript > 正文

微信小程序实现授权登录

2019-11-19 11:34:24
字体:
来源:转载
供稿:网友

前言:由于微信官方修改了 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;   }  }); }, })

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表