解决vue登录信息不及时更新问题

简介: 解决vue登录信息不及时更新问题


前言

现在是:2022年5月20日09:59:34

前面写过一篇文章,基于bladex框架实现的模拟登录,后来在测试的过程中发现了个问题,即A系统在跳转到本系统时,携带用户名和密码进行登录本系统是没有问题的;但是当A系统切换了别的用户,再跳转到本系统时,则本系统的用户信息还是上一个用户的信息,没有及时更新过来,本篇文章就是对这一问题的解决。

思路

出现这个问题的原因:

  1. 没有清空登录信息
  2. 没有重新登录

所以基于这两点出发,原来想的是在登录之前,先调用一下退出的方法,然后重新登录,后来同事说不用那么麻烦,直接在permission.js文件中做登录操作就行,于是,我就照做了。

整体思路是这样的:

  • 获取地址栏中参数
  • 解析拿到用户信息
  • 调用模拟登陆方法
  • 将需要用到的值放在sessionStorage
  • 重定向到首页(去掉地址栏中挂的参数)

实现代码

router.beforeEach((to, from, next) => {})中的代码如下:

//拿到地址栏中的参数
  //获取顶部链接
  let domain = getTopUrl();
  //查找有没有?,有的话是三方过来的用户,没有的话就是本系统的
  if(domain.indexOf("?")>0) {
    //获取参数
    let training = getQueryString("training");
    //去掉后面的#login
    if (training.indexOf("#/") > 0) {
      training = training.split("#/")[0];
    }
    var up = jiexicode(training);
    var username = up.split(",")[0];
    var password = '';
    if (up.indexOf("&memberid=") > 0) {
      //会员
      password = (up.split(",")[1]).split("&memberid=")[0];
      //将会员id放在本地
      sessionStorage.setItem("memberid", (up.split(",")[1]).split("&memberid=")[1]);
      sessionStorage.setItem("tag", 0);
    } else if (up.indexOf("&groupId=") > 0) {
      //团组
      password = (up.split(",")[1]).split("&groupId=")[0];
      //将团组id放在本地
      sessionStorage.setItem("groupId", (up.split(",")[1]).split("&groupId=")[1]);
      sessionStorage.setItem("tag", 1);
    }
    var loginForm = {
      username: username,
      password: password,
    };
    //异步进行登录
    store.dispatch("LoginPrammeSystem", loginForm).then(res => {
      console.log("进来了permission.js的登陆的方法", domain);
      location.href = location.origin;
    });
    return;
  }

注意事项

  1. return一定要加上
  2. 重定向地址栏中的链接时,一定要将参数去掉
  3. 以上两点只要有一点疏忽,则就会造成死循环!!!
目录
相关文章
|
3天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
2天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
8 1
|
2天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
10 0
|
2天前
|
JavaScript
vue知识点
vue知识点
10 0
|
3天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
3天前
|
JavaScript 数据库
ant design vue日期组件怎么清空 取消默认当天日期
ant design vue日期组件怎么清空 取消默认当天日期
|
3天前
|
JavaScript C++
vue高亮显示组件--转载
vue高亮显示组件--转载
8 0
|
3天前
|
JavaScript 前端开发 数据安全/隐私保护
揭秘Vue中v-model的内部工作机制
揭秘Vue中v-model的内部工作机制
|
3天前
|
JavaScript
Vue中避免滥用this去读取data中数据
Vue中避免滥用this去读取data中数据
|
3天前
|
JavaScript
vue中使用pinia及持久化
vue中使用pinia及持久化
6 0