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

    关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难理解的一种方法。

    项目中有一些路由是需要登录才可以进入的,比如首页,个人中心等等
    有一些路由是不需要登录就可以进入,比如登录页,注册页,忘记密码等等
    那如何判断路由是否需要登录呢?就要在路由JS里面做文章

    在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: {
        //获取登录状态
        userLogin({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);
    });

    这样就已经完成了Vue的登录注册,当用户关闭浏览器或者第二天再次进入网站,用户依旧可以保持着登录的状态直到用户手动退出登录。

    Tips:用户退出只需要localStorage.removeItem("Flag")即可

    参考---https://segmentfault.com/a/1190000016040068

  • 相关阅读:
    eclipse打包
    java reflect 小例子
    linux查看java jdk安装路径和设置环境变量
    mapreduce (一) 物理图解+逻辑图解
    java url 解码 编码 奇怪的解码两次
    cygwin+hadoop+eclipse (三) 运行wordcount实例
    nutch 与 solr 的结合
    一个项目可以有多个源代码路径
    SHAppBarMessage
    记录系统开机启动登录注销等信息
  • 原文地址:https://www.cnblogs.com/pwindy/p/14500713.html
Copyright © 2011-2022 走看看