用户登录与信息管理:实现小程序登录与用户信息存储

用户登录与信息管理:实现小程序登录与用户信息存储

在现代的移动应用中,用户登录与信息管理是构建个性化用户体验的基础。小程序作为轻量级的应用形式,在简化开发流程的同时,也需要我们妥善管理用户的登录状态与用户信息。本文将详细介绍如何在小程序中实现用户登录功能,并将用户信息存储到全局状态管理对象Store中,以便在应用的不同部分高效访问这些信息。

程序登录图示

在深入探讨之前,让我们先通过一个简单的图示了解小程序登录的流程:

  1. 开发者服务器(后端):负责处理小程序端发送的请求,包括验证用户身份、生成并管理自定义登录态(token)。
  2. 前端(小程序):负责触发登录流程,获取临时登录凭证(code),并发送至后端以换取自定义登录态(token)。前端保存这个token,并在后续请求中携带。
  3. 后端流程 :在接收到code后,后端将其发送到微信接口服务,以获取session_key和openid。后端将这些信息与自定义的token关联起来,并返回给前端。后续的请求中,后端会校验token的有效性。
用户登录:实现小程序登录功能

步骤1:创建登录API函数

/api/user.js文件中,根据接口文档,创建一个用于登录的API函数login

javascript 复制代码
// /api/user.js
import http from '../utils/http'

/**
 * @description 授权登录
 * @param {*} code 临时登录凭证code
 * @returns Promise
 */
export const reqLogin = (code) => {
  return http.get(`/weixin/wxLogin/${code}`)
}

步骤2:绑定登录按钮事件

为登录按钮绑定点击事件,对应login回调函数。

步骤3:调用wx.login方法

login回调函数中,调用wx.login方法获取临时登录凭证code

步骤4:调用登录API

/pages/login/login.js中导入封装好的API函数,传入code并调用。

javascript 复制代码
// /pages/login/login.js
import { reqLogin } from '../../api/user'
import { toast } from '../../utils/extendApi'

Page({
  // 点击登录
  login() {
    // 调用 wx.login 获取用户信息
    wx.login({
      success: async ({ code }) => {
        if (code) {
          // 调用接口 API,传入 code 进行登录
          const res = await reqLogin(code)

          // 登录成功以后将 token 存储到本地
          wx.setStorageSync('token', res.data.token)

          // 返回之前的页面
          wx.navigateBack()
        } else {
          // 登录失败后给用户进行提示
          toast({ title: '授权失败,请稍后再试~~~' })
        }
      }
    })
  }
})

步骤5:使用MobX进行全局状态管理

为了实现全局状态管理,我们将使用MobX。首先,安装MobX相关的包。

bash 复制代码
npm i mobx-miniprogram mobx-miniprogram-bindings

步骤6:创建Store

在项目的根目录下创建store文件夹,并在该文件夹下新建userstore.js。导入核心的observableaction方法,创建Store,同时声明数据和方法。

javascript 复制代码
// /store/userstore.js
import { observable, action } from 'mobx-miniprogram'
import { getStorage } from '../utils/storage'

// 创建 store 对象,存储应用的状态
export const userStore = observable({
  // 创建可观察状态 token
  token: getStorage('token') || '',

  // 对 token 进行修改
  setToken: action(function (token) {
    this.token = token
  })
})

步骤7:关联页面与Store

在登录页面,导入ComponentWithStore方法,并配置storeBindings方法让页面和Store对象关联。

javascript 复制代码
// /pages/login/login.js
import { reqLogin } from '../../api/user'
import { userStore } from '../../store/userstore'
import { ComponentWithStore } from 'mobx-miniprogram-bindings'

ComponentWithStore({
  storeBindings: {
    store: userStore,
    fields: ['token'],
    actions: ['setToken']
  },
  methods: {
    // 授权登录
    login() {
      wx.login({
        success: async ({ code }) => {
          if (code) {
            const { data } = await reqLogin(code)

            // 将数据存储到本地和 store 对象中
            wx.setStorageSync('token', data.token)
            this.setToken(data.token)
          } else {
            toast({ title: '授权失败,请重新授权' })
          }
        }
      })
    }
  }
})
用户信息:将用户信息存储到Store

步骤1:新增userInfo字段

store/userstore.js中新增userInfo字段,同时创建修改的action方法。

javascript 复制代码
// /store/userstore.js
export const userStore = observable({
  // ...其他字段
  // 用户信息
  userInfo: wx.getStorageSync('userInfo') || {},

  // 设置用户信息
  setUserInfo: action(function (userInfo) {
    this.userInfo = userInfo
  })
})

步骤2:封装获取用户信息的API函数

/api/user.js文件中,根据接口文档,创建获取用户信息的API函数reqUserInfo

javascript 复制代码
// /api/user.js
export const reqUserInfo = () => {
  return http.get(`/mall-api/weixin/getuserInfo`)
}

步骤3:在登录成功后获取用户信息

在登录成功以后,调用获取用户信息的接口,并将用户信息存储到本地和Store中。

javascript 复制代码
// /pages/login/login.js
import { reqLogin, reqUserInfo } from '../../api/user'
import { setStorage } from '../../utils/storage'

ComponentWithStore({
  // ...其他配置
  methods: {
    // 授权登录
    login() {
      wx.login({
        success: async ({ code }) => {
          if (code) {
            const { data } = await reqLogin(code)

            // 存储 token 并设置 token
            wx.setStorageSync('token', data.token)
            this.setToken(data.token)

            // 获取用户信息
            this.getUserInfo()
          } else {
            toast({ title: '授权失败,请重新授权' })
          }
        }
      })
    },

    // 获取用户信息
    async getUserInfo() {
      const { data } = await reqUserInfo()
      // 将用户信息存储到本地和 Store
      setStorage('userInfo', data)
      this.setUserInfo(data)
    }
  }
})

总结

通过上述步骤,我们成功实现了小程序的用户登录功能,并将用户信息存储到了全局状态管理对象Store中。这不仅能够简化用户信息的访问,还能提升应用在不同页面之间传递数据的效率。利用MobX进行全局状态管理,我们能够更好地管理应用的复杂状态,为用户提供更加流畅和个性化的体验。

相关推荐
理想不理想v4 分钟前
vue经典前端面试题
前端·javascript·vue.js
不收藏找不到我5 分钟前
浏览器交互事件汇总
前端·交互
YBN娜19 分钟前
Vue实现登录功能
前端·javascript·vue.js
阳光开朗大男孩 = ̄ω ̄=19 分钟前
CSS——选择器、PxCook软件、盒子模型
前端·javascript·css
minDuck23 分钟前
ruoyi-vue集成tianai-captcha验证码
java·前端·vue.js
小政爱学习!44 分钟前
封装axios、环境变量、api解耦、解决跨域、全局组件注入
开发语言·前端·javascript
魏大帅。1 小时前
Axios 的 responseType 属性详解及 Blob 与 ArrayBuffer 解析
前端·javascript·ajax
花花鱼1 小时前
vue3 基于element-plus进行的一个可拖动改变导航与内容区域大小的简单方法
前端·javascript·elementui
k09331 小时前
sourceTree回滚版本到某次提交
开发语言·前端·javascript
EricWang13581 小时前
[OS] 项目三-2-proc.c: exit(int status)
服务器·c语言·前端