实现uniapp小程序中的“一次绑定,永久登录”的功能

本文详细描述了前端和后端在微信登录过程中如何获取code、验证手机号和验证码,以及使用JWTToken进行用户身份验证。强调了JWTToken的使用、设置过期时间和优化用户体验的方法,以实现永久登录的效果。
摘要由CSDN通过智能技术生成

首次登录并绑定手机号

  1. 前端
    • 用户点击登录按钮,触发登录流程。
    • 调用wx.login获取code
    • 提示用户输入手机号和验证码。
    • code、手机号和验证码发送到后端。
  2. 后端
    • 接收前端发送的code、手机号和验证码。
    • 使用code调用微信接口换取session_keyopenid
    • 验证手机号和验证码的有效性。
    • 如果验证通过,将手机号与openid绑定到数据库中。
    • 生成一个登录态凭证(如JWT token),并返回给前端。

后续登录(使用code直接登录)

  1. 前端
    • 用户点击登录按钮,触发登录流程。
    • 调用wx.login获取code
    • code发送到后端。
    • 如果后端返回了有效的token,则存储token并视为登录成功;如果token无效或过期,则提示用户重新登录或自动重新发起登录流程。
  2. 后端
    • 接收前端发送的code
    • 使用code调用微信接口换取session_keyopenid
    • 根据openid在数据库中查找绑定的手机号。
    • 如果找到手机号,则验证登录态凭证(如JWT token)的有效性。
    • 如果token有效,更新token的过期时间并返回给前端;如果token无效或过期,则重新生成一个新的token并返回

实现细节

  • JWT Token:JWT是一种常用的登录态凭证,它可以在前后端之间安全地传递用户信息。可以使用开源库(如JSON Web Token for Java)来生成和验证JWT。
  • Token过期:可以设置JWT的过期时间,并在每次验证token时检查其是否过期。如果过期,可以要求用户重新登录或自动重新发起登录流程以获取新的token。
  • 用户体验:为了提高用户体验,可以在用户登录成功后设置一个较长的token过期时间,并在用户每次使用应用时自动刷新token的过期时间,以实现“永久登录”的效果。但这并不意味着真正的永久登录,因为用户仍然可能通过清除缓存、更换设备等方式导致登录态失效。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值