//app.js
App({
onLaunch: function () {
// 展示本地存储能力
var logs = wx.getStorageSync('logs') || []
logs.unshift(Date.now())
wx.setStorageSync('logs', logs)
console.log('logs',logs)
// 登录
wx.login({
success: res => {
console.log('微信login状态',res)
// 发送 res.code 到后台换取 openId, sessionKey, unionId
wx.request({
url: 'https://XXXX.com/index.php/Api/Weixin/code_to_openidv2',
data: {
'code': res.code,
'from': 'wxbcee09d68a8073ac'
},
success: function (res) {
console.log("获取openid状态res",res.data)
//将SESSIONID保存到本地storage
wx.setStorageSync('jiaoxue_OPENID', res.data.openid)
// 发送openid到后台,查询是否注册,注册成功就返回相关的信息。
wx.request({
url: 'https://XXX.com/index.php/Api/User/getInfo',
data: {
'openid': res.data.openid,
},
success: function (res1) {
console.log('获取用户信息res1',res1)
wx.setStorageSync('userInfo', res1.data.data)发送openid 获取用户信息,成功后的用户信息写入到本地缓存。
},
})
if (!res.data.is_register) { // 判断是否已经注册,没有注册 提示注册 ,若返回的数据显示是注册的,就直接跳过了
wx.showModal({
title: '提示',
content: '请先注册',
showCancel: false,
confirmText: "确定",
success: function (res) {
console.log("res",res)
wx.navigateTo({
url: '/pages/register/userlogin',
})
}
})
}
},
fail: function (res) {
console.log('res' + res)
}
})
}
})
// 获取用户信息
wx.getSetting({
success: res => {
console.log('wx.getSetting信息',res) // app启动后,第一条是logs 第二条就是执行这条语句
if (res.authSetting['scope.userInfo']) {
// 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
wx.getUserInfo({
success: res => {
console.log('wx.getUserInfo',res) // 可以获取到用户的登入信息,如昵称等。。。
// 可以将 res 发送给后台解码出 unionId??需要解码才能在手机客户端上显示头像和昵称吗?
this.globalData.userInfo = res.userInfo
// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
// 所以此处加入 callback 以防止这种情况
if (this.userInfoReadyCallback) {
this.userInfoReadyCallback(res)
}
}
})
}
}
})
},
// 在 app.js中定义一个全局的变量
globalData: {
userInfo: null
}
})
小程序中在app.js中编写wx.login函数
最新推荐文章于 2024-07-30 10:02:03 发布