zoukankan      html  css  js  c++  java
  • Vue+localstrong登录注册,并保持登录状态

    在router.js中添加meta区分

    比如登录注册页面,不需要登录即可进入,那么我们把meta中的isLogin标志设置为false

    {
      //登录
      path: '/login',
      component: login,
      meta: {
        isLogin: false
      }
    },
    {
      //注册
      path: '/register',
      component: register,
      meta: {
        isLogin: false
      }
    },

    而在首页我们需要登录才能进入,那么我们把meta中的isLogin标志设置为true

    {
      //首页
      path: '/home',
      component: home,
      meta: {
        isLogin: true
      },
    }

    这样我们就为进入各个路由是否需要登录做了区分。

    接下来我们在login.vue中修改登录后状态

    我们使用axios向后台发起登录请求

    this.$axios.post("/xxx/login", {user:name,password:pwd})
        .then(data => {
            //登录失败,先不讨论
            if (data.data.status != 200) {
              //iViewUi的友好提示
              this.$Message.error(data.data.message);
            //登录成功
            } else {
              //设置Vuex登录标志为true,默认userLogin为false
              this.$store.dispatch("userLogin", true);
              //Vuex在用户刷新的时候userLogin会回到默认值false,所以我们需要用到HTML5储存
              //我们设置一个名为Flag,值为isLogin的字段,作用是如果Flag有值且为isLogin的时候,证明用户已经登录了。
              localStorage.setItem("Flag", "isLogin");
              //iViewUi的友好提示
              this.$Message.success(data.data.message);
              //登录成功后跳转到指定页面
              this.$router.push("/home");
            }
     });

    Vuex里面我是这样写的(如果项目不需要Vuex,那么直接使用HTML5储存就可以了):

    export const store = new Vuex.Store({
      // 设置属性
      state: {
        isLogin: false,
      },
    
      // 获取属性的状态
      getters: {
        //获取登录状态
        isLogin: state => state.isLogin,
      },
    
      // 设置属性状态
      mutations: {
        //保存登录状态
        userStatus(state, flag) {
          state.isLogin = flag
        },
      },
    
      // 应用mutations
      actions: {
        //获取登录状态
        setUser({commit}, flag) {
          commit("userStatus", flag)
        },
      }
    })

    在mian.js里

    router.beforeEach((to, from, next) => {
    
      //获取用户登录成功后储存的登录标志
      let getFlag = localStorage.getItem("Flag");
    
      //如果登录标志存在且为isLogin,即用户已登录
      if(getFlag === "isLogin"){
    
        //设置vuex登录状态为已登录
        store.state.isLogin = true
        next()
    
        //如果已登录,还想想进入登录注册界面,则定向回首页
        if (!to.meta.isLogin) {
           //iViewUi友好提示
          iView.Message.error('请先退出登录')
          next({
            path: '/home'
          })
        }
      
      //如果登录标志不存在,即未登录
      }else{
    
        //用户想进入需要登录的页面,则定向回登录界面
        if(to.meta.isLogin){
          next({
            path: '/login',
          })
          //iViewUi友好提示
          iView.Message.info('请先登录')
        //用户进入无需登录的界面,则跳转继续
        }else{
          next()
        }
    
      }
    
    });
    
    router.afterEach(route => {
      window.scroll(0, 0);
    });

     

  • 相关阅读:
    PHP中的__clone()
    如何使用windows的计划任务?计划任务?
    (mysql)触发器、事件、事务、函数
    mysql子查询 exists,not exists,all和any
    MySQL 获得当前日期时间时间戳 函数
    JavaScript从数组中删除指定值元素的方法
    monorepo仓库管理方式探秘
    浏览器和Node 中的Event Loop
    Promise原理探究及实现
    yarn or npm 版本固化如何选择
  • 原文地址:https://www.cnblogs.com/AlbertP/p/10741268.html
Copyright © 2011-2022 走看看