当前位置: 首页 > article >正文

记录一次登录相关bug

原因

我发现我的登录是有问题的,起初我是觉得是session的问题
下面先回顾一下页面的四种本地保存方式
链接
https://blog.csdn.net/YN2000609/article/details/131709478
大概的有四种 ,其中他们的存储时间分别是
IndexedDB 的数据存储时间最长,Local Storage 的数据存储时间次长,Cookie 的数据存储时间相对较长,而 Session Storage 的数据存储时间最短。
他们的存储失效界限是
indexeddb是没有 local storeage也是没有 浏览器关闭还存着 cookie是自行设置时间,如果不设置时间就是刷新还有 浏览器关闭就没 session是如果不设置时间是刷新就没
不巧我使用的就是session
我起初觉得是这个session的问题 但是我这个框架内置了登录刷新的一些逻辑 太多了我没有看 所以就无脑把时间都加成了一个小时 也就是把expires改成正常时间加一个小时。但是发现刷新之后还是没了,没了就是存储的用户名为空,我在想是哪里 结果就发现是一段这样的代码

  if (data.userId && data.roles) {
    console.log("如果都在")
    console.log(data.userId)
    const { userId, roles } = data;
    setSessionKey(userId, roles);
  } else {

    console.log(data)
    const userId =
      storageSession().getItem<DataInfo<number>>(sessionKey)?.userId ?? "";
    const roles =
      storageSession().getItem<DataInfo<number>>(sessionKey)?.roles ?? [];
    setSessionKey(userId, roles);
  }
}

把session里面的username改成了”“也就是空,但是逻辑根本不对 他是在用户名和权限其一不再的时候才运行的,然后想到我的roleid是0 会不会在if中被看作false 的存在,
改成
if (data.userId && data.roles != null) {
console.log(“如果都在”)
console.log(data.userId)
const { userId, roles } = data;
setSessionKey(userId, roles);
} else {

console.log(data)
const userId =
  storageSession().getItem<DataInfo<number>>(sessionKey)?.userId ?? "";
const roles =
  storageSession().getItem<DataInfo<number>>(sessionKey)?.roles ?? [];
setSessionKey(userId, roles);

}
}果然就没运行了

错误原因

1 是接口返回的roles的值是number类型的 而框架内都是以string形式存储的 所以在返回数据的时候,数字0被当成了为空也就是false
2 刷新的逻辑和登录逻辑重叠 不易维护
3 返回数据的时候前端期望后端返回的是username 但是后端偏偏返回了userid 就常常获取不到值
4 session不够持久化存储就一直每次刷新的时候重新获取 不符合规范


http://www.kler.cn/news/150193.html

相关文章:

  • Hive_last_value()
  • 解决QT信号在信号和槽连接前发出而导致槽函数未调用问题
  • 爬虫代理技术与构建本地代理池的实践
  • 亚马逊云科技向量数据库助力生成式AI成功落地实践探秘(二)
  • Java LeetCode篇-深入了解关于单链表的经典解法
  • Linux命令中的符号
  • 初学者如何入门深度学习:以手写数字字符识别为例看AI 的学习路径,一图胜千言!
  • 福德植保无人机:农业科技的新篇章
  • 小航助学题库蓝桥杯题库c++选拔赛(23年8月)(含题库教师学生账号)
  • 卷积神经网络(CNN)注意力检测
  • 统计英语单词
  • 在Docker上部署Springboot项目
  • 大一学编程怎么学?刚接触编程怎么学习,有没有中文编程开发语言工具?
  • 为什么预处理对象会提升处理的性能
  • 线性可分SVM摘记
  • java学习part23异常try catch
  • Elasticsearch:ES|QL 函数及操作符
  • HTTP常见响应码
  • 小航助学题库蓝桥杯题库c++选拔赛(22年1月)(含题库教师学生账号)
  • 对话式数据需求激增,景联文科技提供高质量多轮对话数据定制采集标注服务
  • 20. Matplotlib 数据可视化
  • 企业微信http协议接口调用,发送视频号消息
  • 荣耀冲击高端,一边推新「修路」,一边降价「拆桥」
  • 网络相关-面试高频
  • 自动化测试工具——Monkey
  • GANVAEDiffusion
  • Mysql之子查询(知识点+例题)
  • 知识蒸馏相关基础知识
  • Vue3框架中让table合计居中对齐
  • 自定义类型:结构体,枚举,联合