Vue实现登录以及登出详解

作者:难过的新手村 时间:2023-07-02 16:59:51 

首先先了解一下,我们的效果实现流程

首先登录概述及业务流程和相关技术点

  • 录页面的布局

  • 创建两个Vue.js文件

  • 一个我们来做登录页和注册页

  • 登录页面的布局

  • 配置路由

  • 登录表单的数据绑定

  • 登录表单的验证规则

  • 登录表单的重置

  • 登录预验证

  • 登录组件配置弹窗提示

  • 登录成功后的行为

  • 将登录之后的token,保存到客户端的sessionStorage中

  • 通过编程式导航跳转到后台主页,路由地址是默认路径 '/'

  • 在我们首页的登出,组件配置弹窗提示,把我们的token使用removeItem删除

登录业务流程

1.在登录页面输入用户名和密码

2.调用后台接口进行验证

3.通过验证之后,根据后台得响应状态跳转到项目主页

登录功能实现

1.首先我们用路由守卫来验证登录,判断是否与需要登录


{
   path:'/login',
   name:"login",
   component:login,
   meta:{
     login:true
   }
}
 // 需要登录的地方定义meta-true  看他需不需要登录
  if(to.matched.some(item=>item.meta.login)){//需要登录
   console.log("需要登录");
   if(isLogin){//1.已经登录,直接通过
       if(data.error===400){//后端告诉你,登录不成功
           next({name:'login'})
           localStorage.removeItem('token');
           return;
       }
       if(to.name==='login'){
           next({name:'Home'})
       }else{
           next()
       }
       return;
   }
   if(!isLogin && to.name==='login'){//2.未登录,但要去登录页
       next()
   }
   if(!isLogin && to.name !=='login'){//3.未登录,去的也不是登录页
       next({name:"login"})
   }
  }else{//不需要登录直接进
      next()
  }

2.表单的验证规则,我们用的是Element的组件库

在模板中用Element编写我们的样式布局


<div class="login-section">
   <!-- :rules="rules" -->
   <el-form
     label-position="top"
     label-width="100px" class="demo-ruleForm"
     :rules="rules"
     :model="rulesFrom"
     status-icon
     ref="ruleFrom"
   >
     <el-form-item label="用户名" prop="name">
       <!--             使用v-model来获取用户输入的名字                    -->
       <el-input type="text" v-model="rulesFrom.name"></el-input>
     </el-form-item>
     <el-form-item label="密码" prop="password"></el-form-item>
       <!--             使用v-model来获取用户输入的密码                    -->
       <el-input type="password" v-model="rulesFrom.password"></el-input>
     </el-form-item>
     <el-form-item>
       <!--                    定义提交事件             -->
       <el-button type="primary" @click="submitFrom('ruleFrom')">提交</el-button>
       <el-button>重置</el-button>
     </el-form-item>
   </el-form>
 </div>

定义表单的验证规则

Vue实现登录以及登出详解

详细的看Element官网from表单

在Data里面定义


rulesFrom:{
       name:'',
       password:''
     },
     rules:{
       name:[
         // 验证规则
         {required:true,message:'请输入用户名',trigger:'blur'},
         {min:1,max:5,message:'长度在1到5个字符',trigger:'blur'}
       ],
       password:[
         {required:true,message:'请输入密码',trigger:'blur'},
         {min:1,max:5,message:'长度在1到5个字符',trigger:'blur'}
       ]
     }

在methods定义提交事件


// 当我们点击提交的时候能出发方法能拿到表单的所有东西
   submitFrom(formName){
     this.$refs[formName].validate( (valid)=>{
       if(valid){
         // 如果校检通过,再里向后端返送用户信息和密码
         login({
           name:this.rulesFrom.name,
           password:this.rulesFrom.password,
         }).then((data)=>{
           console.log(data);
           if(data.code===0){
             localStorage.setItem('token',data.data.token)
             window.location.href='/';
           }
           if(data.code===1){
             this.$message.error(data.mes)
           }
         })
       }else{
         console.log('error submit!!');
         return false
       }
     })
   }

这个时候把登出也写一下在router beforeEach中给他转换


const token=localStorage.getItem('token');
//    !!token转换成布尔类型
  const isLogin=!!token;
//    进入路由的时候,需要向后端返送token,验证是否合法
   const data=await userInfo();
   Store.commit('chageUserInfo',data.data)

来源:https://blog.csdn.net/weixin_57259948/article/details/120439822

标签:Vue,登陆
0
投稿

猜你喜欢

  • anconda的pip下载包出现的问题解决

    2022-06-21 22:17:33
  • python numpy实现文件存取的示例代码

    2022-01-11 07:14:58
  • 纯手工打造CSS像素画

    2009-03-09 12:57:00
  • windows下安装Python虚拟环境virtualenvwrapper-win

    2023-12-23 11:24:08
  • python性能测试手机号验证码登录压测示例详解

    2021-06-05 13:21:25
  • JavaScript遍历求解数独问题的主要思路小结

    2023-10-13 16:41:14
  • PyTorch搭建CNN实现风速预测

    2022-09-11 17:40:19
  • Vue+Element自定义纵向表格表头教程

    2023-07-02 17:10:38
  • Tensorflow: 从checkpoint文件中读取tensor方式

    2022-07-20 11:39:29
  • 树莓派(python)与arduino串口通信的详细步骤

    2022-05-29 15:31:06
  • CSS 的优先规则

    2009-01-08 12:40:00
  • python实战之百度智能云使人像动漫化

    2021-01-19 07:15:11
  • Pandas替换及部分替换(replace)实现流程详解

    2023-11-04 02:58:38
  • sklearn的predict_proba使用说明

    2023-10-24 11:22:08
  • 手把手带你了解Python数据分析--matplotlib

    2022-05-21 22:07:18
  • MySQL性能诊断与调优工具

    2010-11-02 11:41:00
  • python 实现在Excel末尾增加新行

    2023-11-26 09:27:52
  • python3实现飞机大战

    2023-03-03 00:36:18
  • MySQL获取当前时间的多种方式总结

    2024-01-21 02:29:34
  • 保护MySQL数据库中重要数据的注意事项

    2009-01-19 11:55:00
  • asp之家 网络编程 m.aspxhome.com