返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue实现登录以及登出详解
  • 466
分享到

Vue实现登录以及登出详解

2024-04-02 19:04:59 466人浏览 独家记忆
摘要

目录登录业务流程登录功能实现总结首先先了解一下,我们的效果实现流程 首先登录概述及业务流程和相关技术点 录页面的布局 创建两个vue.js文件 一

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

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

  • 录页面的布局
  • 创建两个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>

定义表单的验证规则

详细的看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)

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: Vue实现登录以及登出详解

本文链接: https://lsjlt.com/news/136576.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue实现登录以及登出详解
    目录登录业务流程登录功能实现总结首先先了解一下,我们的效果实现流程 首先登录概述及业务流程和相关技术点 录页面的布局 创建两个Vue.js文件 一...
    99+
    2024-04-02
  • Vue登录功能的实现流程详解
    目录Vue项目中实现登录大致思路安装插件创建store封装axiosqs vue 插件api.js的作用路由拦截登录页面实际使用Vue项目中实现登录大致思路 1、第一次登录的时候,前...
    99+
    2024-04-02
  • Vue实现用户登录及token验证
    在前后端完全分离的情况下,Vue项目中实现token验证大致思路如下: 1、第一次登录的时候,前端调后端的登陆接口,发送用户名和密码 2、后端收到请求,验证用户名和密码,验证成功,就...
    99+
    2024-04-02
  • Python 登录网站详解及实例
    Python 登录网站详解及实例 对于大部分论坛,我们想要抓取其中的帖子分析,首先需要登录,否则无法查看。   这是因为 HTTP 协议是一个无状态(Stateless)的协议,服务器如何知道当前请求连接的...
    99+
    2022-06-04
    详解 实例 网站
  • Vue登录功能实现
    目录写在前面登录概述登录业务流程登录业务的相关技术点登录—token原理分析登录功能实现登录表单的布局登录表单的数据绑定登录表单的验证规则登录表单的重置登录预验证登录组件配置弹窗提示...
    99+
    2024-04-02
  • vue实现登录界面
    使用Vue实现简单的用户登录界面,登录成功以后查询账号用户类型进行相应的页面路由跳转,效果如下图所示: HTML部分: <div class="loginbody"> ...
    99+
    2024-04-02
  • VUE使用localstorage和sessionstorage实现登录示例详解
    目录正文localstroage就是一个加强版的COOKIE。三者的异同localStorage和sessionStorage操作登录实例:Router.js正文 今天这篇日志记录下...
    99+
    2022-11-13
    VUE实现登录 VUE localstorage和sessionstorage
  • SpringSecurityOAuth2单点登录和登出的实现
    目录1. 单点登录1.1 使用内存保存客户端和用户信息1.2 使用数据库保存客户端和用户信息1.3 单点登录流程1.3 JWT Token2. 单点登出3. 总结参考:Spring ...
    99+
    2024-04-02
  • Android 实现微信登录详解
    前言  分享到微信朋友圈的功能早已经有了,但微信登录推出并不久,文档写的也并不是很清楚,这里记录分享一下。  正文  一、准备  &nb...
    99+
    2022-06-06
    Android
  • springboot+VUE实现登录注册
    本文实例为大家分享了springboot+VUE实现登录注册的具体代码,供大家参考,具体内容如下 一、springBoot 创建springBoot项目 分为三个包,分别为contr...
    99+
    2024-04-02
  • springboot+vue实现登录功能
    本文实例为大家分享了springboot+vue实现登录功能的具体代码,供大家参考,具体内容如下 目录结构 前端端口:8080 后端端口:8900 login.vue <...
    99+
    2024-04-02
  • vue+springboot实现登录功能
    本文实例为大家分享了vue+springboot实现登录功能的具体代码,供大家参考,具体内容如下 1. 登录功能的实现 实现提交表单的代码如下: async submitForm...
    99+
    2024-04-02
  • vue实现登录验证码
    本文实例为大家分享了vue实现登录验证码的具体代码,供大家参考,具体内容如下 先来demo效果图 canvas验证码组件(可直接复制,无需改动) <template>...
    99+
    2024-04-02
  • VUE实现token登录验证
    本文实例为大家分享了VUE实现token登录验证的具体代码,供大家参考,具体内容如下 实现这个登录功能的过程真是一波三折,中途出现了bug,整了两三天才解决了问题,心力交瘁,简直一个...
    99+
    2024-04-02
  • Vue+Vux实现登录功能
    一、准备工作 请参照 Vue前端框架搭建 使用模板创建框架。 二、创建登录页 1.main.js 中引入全局 ToastPlugin、LoadingPlugin 插件 import ...
    99+
    2024-04-02
  • 详解Vue PC端如何实现扫码登录功能
    本篇文章给大家带来了关于Vue的相关知识,其中主要介绍了在PC端实现扫码的原理是什么?怎么生成二维码图片?怎么用Vue实现前端扫码登录?感兴趣的朋友,下面一起来看一下吧,希望对大家有帮助。.markdown-body{word-break:...
    99+
    2023-05-14
    前端 Vue.js
  • Vue登录功能实现全套详解(含封装axios)
    目录Vue项目中实现登录大致思路: 一、安装插件二、创建store 三、封装axiosapi.js的作用 四、路由拦截五、登录页面实际使用总结Vue项目...
    99+
    2022-12-28
    vue的登录功能的实现 vue怎么实现登录 vue实现用户登录
  • vue关闭浏览器退出登录怎么实现
    本篇内容介绍了“vue关闭浏览器退出登录怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、beforeunload事件1、菜鸟教程:...
    99+
    2023-06-21
  • vue实现登录类型切换
    本文实例为大家分享了vue实现登录类型切换的具体代码,供大家参考,具体内容如下 运行效果 代码 <!DOCTYPE html> <html lang="en"...
    99+
    2024-04-02
  • vue实现用户登录切换
    本文实例为大家分享了vue实现用户登录切换的具体代码,供大家参考,具体内容如下 切换有问题 代码 <!DOCTYPE html> <html lang="en"...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作