微信小程序开发之简单的授权登录
<view class="container">
<view class=\'content\'>
<view>申请获取以下权限</view>
<text>获得你的公开信息(昵称,头像等)</text>
</view>
<button class=\'bottom\' wx:if="{{canIUse}}" open-type="getUserInfo" bindgetuserinfo="bindGetUserInfo" type=\'primary\'> 授权登录</button>
</view>
点击授权登录按钮
按钮的点击事件
第一次授权之后登录并将code交互
其中一些官方授权的代码并未删除
//获取应用实例
const app = getApp()
Page({
data: {
canIUse: wx.canIUse(\'button.open-type.getUserInfo\')
},
onLoad: function () {
if (app.globalData.userInfo) {
this.setData({
userInfo: app.globalData.userInfo,
hasUserInfo: true
})
} else if (this.data.canIUse) {
// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
// 所以此处加入 callback 以防止这种情况
app.userInfoReadyCallback = res => {
this.setData({
userInfo: res.userInfo,
hasUserInfo: true
})
}
} else {
// 在没有 open-type=getUserInfo 版本的兼容处理
wx.getUserInfo({
success: res => {
app.globalData.userInfo = res.userInfo
this.setData({
userInfo: res.userInfo,
hasUserInfo: true
})
}
})
}
},
getUserInfo: function (e) {
app.globalData.userInfo = e.detail.userInfo
this.setData({
userInfo: e.detail.userInfo,
hasUserInfo: true
})
},
//按钮的点击事件
bindGetUserInfo: function (res) {
let info = res;
console.log(info);
if (info.detail.userInfo) {
console.log("点击了同意授权");
var that = this
wx.login({
success: function (res) {
if (res.code) {
wx.request({
url: \'http://fa.com/api/schoolreserve/login\',
data: {
code: res.code,
user_info: info.detail.userInfo
},
header: {
\'content-type\': \'application/json\' // 默认值
},
success: function (res) {
var userinfo = {};
userinfo[\'id\'] = res.data.id;
userinfo[\'nickName\'] = info.detail.userInfo.nickName;
userinfo[\'avatarUrl\'] = info.detail.userInfo.avatarUrl;
userinfo[\'user_data\'] = res.data;
wx.setStorageSync(\'userinfo\', userinfo)
that.setData({
userInfo: info.detail.userInfo
})
wx.switchTab({
url: \'../toast/toast\',
})
}
})
} else {
console.log("授权失败");
}
},
})
} else {
//用户按了拒绝按钮
wx.showModal({
title: \'警告\',
content: \'您点击了拒绝授权,将无法进入小程序,请授权之后再进入!!!\',
showCancel: false,
confirmText: \'返回授权\',
success: function (res) {
if (res.confirm) {
console.log(\'用户点击了“返回授权”\')
}
}
})
}
}
})
点击授权之后跳转
重新编译项目
接下来在加载事件中判断受否授权
如果已经授权则重新请求,跳转页面
如果没有授权则加载请求授权的页面
//app.js
App({
onLaunch: function () {
// 展示本地存储能力
var logs = wx.getStorageSync(\'logs\') || []
logs.unshift(Date.now())
wx.setStorageSync(\'logs\', logs)
// 获取用户信息
wx.getSetting({
success: res => {
if (res.authSetting[\'scope.userInfo\']) {
console.log("已经授权")
wx.getUserInfo({
success: res => {
// 可以将 res 发送给后台解码出 unionId
this.globalData.userInfo = res.userInfo
// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
// 所以此处加入 callback 以防止这种情况
if (this.userInfoReadyCallback) {
this.userInfoReadyCallback(res)
}
//调用登录
this.AnginLogin()
wx.switchTab({
url: \'/pages/toast/toast\',
})
}
})
}
}
})
},
// 登录
AnginLogin() {
wx.login({
success: res => {
// 发送 res.code 到后台换取 openId, sessionKey, unionId
if (res.code) {
wx.request({
url: \'http://fa.com/api/schoolreserve/login\',
data: {
code: res.code,
user_info: this.globalData.userInfo
},
success: function (res) {
console.log(\'回调成功\')
wx.setStorageSync(\'token\', res.data.data.token)
wx.setStorageSync(\'user_id\', res.data.data.user_id)
},
complete: function () {
wx.checkSession({
success() {
console.log(\'经过验证,登录有效\')
// session_key 未过期,并且在本生命周期一直有效
},
fail() {
console.log(\'session过期,请重新登录\')
// session_key 已经失效,需要重新执行登录流程
wx.switchTab({
url: \'/pages/authorize/authorize\',
})
}
})
}
})
} else {
console.log(\'登录失败!\' + res.errMsg)
}
}
})
},
globalData: {
userInfo: null
}
})
请发表评论