详解小程序用户登录状态检查与更新实例


Posted in Javascript onMay 15, 2019

这篇文章主要解决以下问题:用户每次登录小程序(包括第一次使用)及点击小程序的每个页面的时候,我们如何判断他当前的登录状态是否过期?如果过期,如何重新获取用户信息并发送至开发者服务器更新用户信息,以及设置新的用户登录状态?

将这个部分单独作为一篇文章有两个原因:

① wx.getUserInfo(OBJECT) 接口调整,废弃了以前直接获取用户信息的方法;

② 上篇文章授权、登录、session_key、unionId 只梳理了登录流程而没有贴实际的代码,所以这篇文章以代码实现为主。

1. 代码逻辑分析

(1)用户登录态过期时间如何设置?

在上篇文章中也有提到过,用户登录态可以通过前端设置和后端设置两种方式进行控制。这里我们在前端进行控制,即利用wx.checkSession() 接口来判断session_key 是否过期来作为用户登录态是否过期的标志。如果过期了,则跳转到统一的登录页面引导用户点击按钮重新授权登录,重新登录之后session_key 会刷新,相当于在获取用户最新信息的同时重新设定了过期时间。

(2)onShow() 与onLoad()

小程序js 中有onShow 与onLoad 两种事件。两种事件的区别就在于onLoad 每次打开小程序只加载一次,跳转到其他页面再回来的时候这个事件就不会再触发。而onShow 则每次进入页面都会触发,所以我们在进入每个页面检查用户登录态是否过期的代码需要放在onShow 中。

(3)重新登录过程分析

如果用户登录态过期,则需要进行重新登录。登录过程在上篇文章中也有讲过。这里再简单梳理一下:前端引导用户点击按钮触发getUserInfo 获取最新用户信息 -> 前端调用wx.login() 获取code -> 前端将code 发送给后端获取openid 和seesion_key -> 后端写session 并返回对应session 的唯一标志 -> 前端存储这个唯一标志。

2. 代码实例

在每个页面的onShow 事件中添加以下代码来检查当前用户登录态是否过期:

wx.checkSession({
 success: function () {
 //session_key 未过期,并且在本生命周期一直有效
 return ;
 },
 fail: function () {
 // session_key 已经失效,需要重新执行登录流程
 wx.navigateTo({
  url: "/pages/authorize/index"
 })
 }
})

因为进入每个页面中都需要进行用户登录态是否过期的检查,所以需要有一个公共的授权页面,当检查不同过的时候,就跳转到这个授权页面引导用户重新进行授权,授权页面authorize 代码如下:

wxml

<view class="container">
 <view style='width:100%;padding-left:30rpx;font-size: 28rpx;margin-top:30rpx;'>1、同意当前小程序获取我的微信头像;</view>
 <view style='width:100%;padding-left:30rpx;font-size: 28rpx;margin-top:30rpx;'>2、同意当前小程序获取我的微信昵称等其他信息;</view>
 <button open-type="getUserInfo" bindgetuserinfo="bindGetUserInfo" class="save-btn">授权登录</button>
</view>

wxss

page{
 height: 100%;
}
.container{
 background-color: #f5f5f9;
 justify-content: initial;
}
.save-btn{
 width: 690rpx;
 height: 80rpx;
 line-height: 80rpx;
 text-align: center;
 margin-top:30rpx; 
 border-radius: 6rpx;
 box-sizing: border-box;
 background-color: #e64340;
 color:#fff;
}

js

// pages/authorize/index.js
var app = getApp();
let Domain = app.globalData.domain;
Page({
 
 /**
 * 页面的初始数据
 */
 data: { },
 
 /**
 * 生命周期函数--监听页面加载
 */
 onLoad: function (options) { },
 
 /**
 * 生命周期函数--监听页面初次渲染完成
 */
 onReady: function () { },
 
 /**
 * 生命周期函数--监听页面显示
 */
 onShow: function () { },
 
 /**
 * 生命周期函数--监听页面隐藏
 */
 onHide: function () { },
 
 /**
 * 生命周期函数--监听页面卸载
 */
 onUnload: function () { },
 
 /**
 * 页面相关事件处理函数--监听用户下拉动作
 */
 onPullDownRefresh: function () { },
 
 /**
 * 页面上拉触底事件的处理函数
 */
 onReachBottom: function () { },
 
 /**
 * 用户点击右上角分享
 */
 onShareAppMessage: function () { },
 bindGetUserInfo: function (e) {
 // 获得最新的用户信息
 if (!e.detail.userInfo){
  return;
 }
 wx.setStorageSync('userInfo', e.detail.userInfo)
 this.checkSessionAndLogin();
 },
 /* 
 这里使用openid 作为与后端session 连接的标志
 检查是否存在openid,即之前是否登录过
  如果登录过,检查session_key 是否过期
  如果过期了,remove openid 重新执行login 并将用户信息发送到服务器端更新
  如果没过期则返回
  如果没登录过则执行login 并将用户信息发送到服务器更新
 */
 checkSessionAndLogin: function () {
 let that = this;
 let thisOpenId = wx.getStorageSync('openid');
 
 // 已经进行了登录,检查登录是否过期
 if (thisOpenId) {
  console.log('have openid')
  wx.checkSession({
  success: function () {
   //session_key 未过期,并且在本生命周期一直有效
   wx.navigateBack({});
  },
  fail: function () {
   console.log('but session_key expired');
   // session_key 已经失效,需要重新执行登录流程
   wx.removeStorageSync('openid');
   that.checkSessionAndLogin();
  }
  })
 } else {
  // 没有进行登录则先进行登录操作
  console.log('do not have openid');
  that.loginAndGetOpenid();
 }
 },
 // 执行登录操作并获取用户openId
 loginAndGetOpenid: function () {
 console.log('do login and get openid');
 let that = this;
 wx.login({
  success: function (res) {
  if (res.code) {
   wx.request({
   url: Domain + '/user/wx_login',
   data: {
    code: res.code
   },
   success: function (res) {
    res = res.data;
    console.log(res)
    // 保存openId,并将用户信息发送给后端
    if (res.code === 0) {
    wx.showModal({
     title: 'set openid',
     content: res.data,
    })
    wx.setStorageSync('openid', res.data);
    that.sendUserInfoToServer();
    } else {
    wx.showModal({
     title: 'Sorry',
     content: '用户登录失败~',
    })
    }
   }
   })
  }
  }
 })
 },
 sendUserInfoToServer: function () {
 
 console.log('now send user info to server');
 let userInfo = wx.getStorageSync('userInfo');
 let thisOpenId = wx.getStorageSync('openid');
 
 userInfo.openid =thisOpenId;
 
 wx.request({
  url: Domain + '/user/updateUser',
  method: 'POST',
  dataType: 'json',
  data: userInfo,
  success: function (res) {
  res = res.data;
  if (res.code === 0) {
   wx.navigateBack({});
  } else {
   wx.showModal({
   title: 'Sorry',
   content: '同步信息出错~',
   })
  }
  }
 })
 }
})

以上所述是小编给大家介绍的小程序用户登录状态检查与更新实例详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
动态加载iframe
Jun 16 Javascript
二级域名或跨域共享Cookies的实现方法
Aug 07 Javascript
js 如何实现对数据库的增删改查
Nov 23 Javascript
js和php如何获取当前url的内容
Sep 22 Javascript
全面解析Bootstrap表单使用方法(表单样式)
Nov 24 Javascript
通过隐藏iframe实现无刷新上传文件操作
Mar 16 Javascript
jquery dialog获取焦点的方法
Feb 09 Javascript
微信小程序 自定义Toast实例代码
Jun 12 Javascript
js es6系列教程 - 新的类语法实战选项卡(详解)
Sep 02 Javascript
浅谈ElementUI中switch回调函数change的参数问题
Aug 24 Javascript
JQuery 实现文件下载的常用方法分析
Oct 29 jQuery
jQuery擦除插件eraser使用方法详解
Jan 11 jQuery
基于vue如何发布一个npm包的方法步骤
May 15 #Javascript
浅谈 Webpack 如何处理图片(开发、打包、优化)
May 15 #Javascript
JavaScript页面倒计时功能完整示例
May 15 #Javascript
vue组件间通信六种方式(总结篇)
May 15 #Javascript
JS正则表达式封装与使用操作示例
May 15 #Javascript
微信小程序实现授权登录
May 15 #Javascript
基于vue实现一个神奇的动态按钮效果
May 15 #Javascript
You might like
全文搜索和替换
2006/10/09 PHP
PHP下10件你也许并不了解的事情
2008/09/11 PHP
PHP使用GIFEncoder类生成gif动态滚动字幕
2014/07/01 PHP
PHP高并发和大流量解决方案整理
2021/03/09 PHP
jQuery 第二课 操作包装集元素代码
2010/03/14 Javascript
纯js实现背景图片切换效果代码
2010/11/14 Javascript
JavaScript OOP面向对象介绍
2010/12/02 Javascript
javascript语言结构小记(一)
2011/09/10 Javascript
namespace.js Javascript的命名空间库
2011/10/11 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
浅谈被jQuery抛弃的函数及替代函数
2015/05/03 Javascript
JS中的Replace方法使用经验分享
2015/05/20 Javascript
详解JavaScript for循环中发送AJAX请求问题
2020/06/23 Javascript
基于BootStrap Metronic开发框架经验小结【六】对话框及提示框的处理和优化
2016/05/12 Javascript
jQuery基于正则表达式的表单验证功能示例
2017/01/21 Javascript
jQuery is not defined 错误原因与解决方法小结
2017/03/19 Javascript
node中的session的具体使用
2018/09/14 Javascript
npm scripts 使用指南详解
2018/10/08 Javascript
实例讲解v-if和v-show的区别
2019/01/31 Javascript
[01:13]这,就是刀塔
2014/07/16 DOTA
学习python之编写简单乘法口诀表实现代码
2016/02/27 Python
Numpy数组转置的两种实现方法
2018/04/17 Python
python中sys.argv函数精简概括
2018/07/08 Python
Python框架Flask的基本数据库操作方法分析
2018/07/13 Python
python使用xlrd和xlwt读写Excel文件的实例代码
2018/09/05 Python
python 随机生成10位数密码的实现代码
2019/06/27 Python
pytorch查看通道数 维数 尺寸大小方式
2020/05/26 Python
python右对齐的实例方法
2020/07/05 Python
使用tkinter实现三子棋游戏
2021/02/25 Python
全方位了解CSS3的Regions扩展
2015/08/07 HTML / CSS
现代家居用品及礼品:LBC Modern
2018/06/24 全球购物
英国的领先快速时尚零售商:In The Style
2019/03/25 全球购物
广告宣传策划方案
2014/05/21 职场文书
幼儿园家长安全责任书
2014/07/22 职场文书
《折线统计图》教学反思
2016/02/22 职场文书
聊聊golang中多个defer的执行顺序
2021/05/08 Golang