IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Web前端vue必做笔记之一:token验证登录状态 -> 正文阅读

[JavaScript知识库]Web前端vue必做笔记之一:token验证登录状态

Web前端vue必做笔记之一:token验证登录状态

当我们登录页不输入账号和密码时,直接访问内容页路径,会发现也可以进行访问,这就会产生一个bug,这是就需要进行token验证登录

<template>
     <div> 
         
            <form @submit.prevent="login">
                 <div>
                      <label for="">用户名:</label>
                      <input type="text" v-model="username">
                 </div>
                 <div>
                      <label for="">密码:</label>
                      <input type="password" v-model="password">
                 </div>
                 <button></button>
            </form>
     </div>
</template>

<script>
export default {
    data(){
         return {
              username:'',
              password:''
         }
    },
     methods:{
           login(){
                  if(this.username === 'admin' && this.password ==='123456'){
                      this.$router.push('/')  
                      localStorage.setItem("token","xiaoming") //本地存储
                  }else{
                      
                      alert("用户名或密码错误!");
                  }
           }
     }
}
</script>
import {createRouter, createWebHashHistory} from 'vue-router'
import Home from './components/Home'
import Blog from './components/Blog'
import Login from './components/Login'
const router = createRouter({
    history:createWebHashHistory(),   //把路由设置为hash模式

    //配置路由
    router:[
          {
              path:'/', //路径
              component:Home     //跳转的组件
          },
          {
              path:'/blog',
              component:Blog
          },
          {
              path:'/login',
              component:Login
          }
    ] 
});

//导航守卫,路由守卫,路由拦截 , 
router.beforeEach((to,from,next)=>{   //from: 从哪来的, to:到那里去的, next:指定页面的跳转   
       //验证token,只有存在token的时候,才能跳转到内容页
       let token = localStorage.getItem("token"); //拿到token
       if( token || to.path === '/login'){
            next()
       }else{
           next('/login')
       }
})
//路由只要一切换就调用这个方法,在这个方法里去检测token,有token就可以访问正常页面,没有就跳转到登录页
 
 export default router   
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-12 19:30:07  更:2021-11-12 19:32:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/10 9:39:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码