当前位置:首页 > VUE

vue实现线上登录

2026-01-16 22:41:18VUE

Vue 实现线上登录

使用 Vue Router 和 Vuex 管理登录状态

安装 Vue Router 和 Vuex 依赖:

npm install vue-router vuex

创建路由配置文件 router/index.js,定义登录路由:

import { createRouter, createWebHistory } from 'vue-router'
import Login from '../views/Login.vue'

const routes = [
  {
    path: '/login',
    name: 'Login',
    component: Login
  }
]

const router = createRouter({
  history: createWebHistory(),
  routes
})

export default router

创建 Vuex store 管理登录状态 store/index.js

import { createStore } from 'vuex'

export default createStore({
  state: {
    isAuthenticated: false,
    user: null
  },
  mutations: {
    setAuth(state, payload) {
      state.isAuthenticated = payload.isAuthenticated
      state.user = payload.user
    }
  },
  actions: {
    login({ commit }, userData) {
      // 调用登录API
      commit('setAuth', {
        isAuthenticated: true,
        user: userData
      })
    },
    logout({ commit }) {
      commit('setAuth', {
        isAuthenticated: false,
        user: null
      })
    }
  }
})

创建登录组件

创建登录页面组件 views/Login.vue

<template>
  <div class="login">
    <form @submit.prevent="handleSubmit">
      <input v-model="username" type="text" placeholder="用户名">
      <input v-model="password" type="password" placeholder="密码">
      <button type="submit">登录</button>
    </form>
  </div>
</template>

<script>
import { mapActions } from 'vuex'

export default {
  data() {
    return {
      username: '',
      password: ''
    }
  },
  methods: {
    ...mapActions(['login']),
    async handleSubmit() {
      try {
        await this.login({
          username: this.username,
          password: this.password
        })
        this.$router.push('/')
      } catch (error) {
        console.error('登录失败:', error)
      }
    }
  }
}
</script>

添加路由守卫

修改 router/index.js 添加全局前置守卫:

router.beforeEach((to, from, next) => {
  const isAuthenticated = store.state.isAuthenticated
  if (to.name !== 'Login' && !isAuthenticated) {
    next({ name: 'Login' })
  } else {
    next()
  }
})

实现 API 请求

创建 api/auth.js 处理登录请求:

import axios from 'axios'

export default {
  login(credentials) {
    return axios.post('/api/login', credentials)
  }
}

更新 Vuex action 使用 API:

actions: {
  async login({ commit }, userData) {
    try {
      const response = await authApi.login(userData)
      commit('setAuth', {
        isAuthenticated: true,
        user: response.data.user
      })
    } catch (error) {
      throw new Error('登录失败')
    }
  }
}

处理 Token 存储

安装 js-cookie 存储 token:

npm install js-cookie

更新登录逻辑存储 token:

import Cookies from 'js-cookie'

actions: {
  async login({ commit }, userData) {
    const response = await authApi.login(userData)
    Cookies.set('token', response.data.token)
    commit('setAuth', {
      isAuthenticated: true,
      user: response.data.user
    })
  }
}

添加请求拦截器自动附加 token:

axios.interceptors.request.use(config => {
  const token = Cookies.get('token')
  if (token) {
    config.headers.Authorization = `Bearer ${token}`
  }
  return config
})

实现自动登录

检查本地存储的 token 实现自动登录:

created() {
  const token = Cookies.get('token')
  if (token) {
    this.$store.dispatch('autoLogin', token)
  }
}

添加 autoLogin action:

actions: {
  async autoLogin({ commit }, token) {
    try {
      const response = await authApi.verifyToken(token)
      commit('setAuth', {
        isAuthenticated: true,
        user: response.data.user
      })
    } catch (error) {
      Cookies.remove('token')
    }
  }
}

vue实现线上登录

标签: 线上vue
分享给朋友:

相关文章

vue实现多选div

vue实现多选div

实现多选 DIV 的基本思路 在 Vue 中实现多选 DIV 功能,可以通过以下方法实现。主要思路是利用 v-model 绑定选中状态,结合 CSS 类名动态切换样式。 数据准备与模板结构 定义一…

vue实现文档分享

vue实现文档分享

Vue 实现文档分享功能 文档分享功能通常涉及文件上传、存储、生成分享链接以及权限控制等模块。以下是基于 Vue 的实现方案: 文件上传组件 使用 element-ui 或 ant-design-v…

vue前端实现搜索

vue前端实现搜索

实现搜索功能的基本方法 在Vue中实现搜索功能通常涉及以下几个关键步骤,结合数据绑定、计算属性和方法调用来动态过滤和显示结果。 数据绑定与输入处理 使用v-model双向绑定搜索输入框的值,监听用…

vue按钮实现截屏

vue按钮实现截屏

Vue 按钮实现截屏的方法 在 Vue 项目中实现截屏功能可以通过多种方式完成,以下是几种常见的方法: 使用 html2canvas 库 安装 html2canvas 库: npm ins…

vue实现签约合作弹窗

vue实现签约合作弹窗

实现签约合作弹窗的步骤 使用Vue实现签约合作弹窗可以通过组件化方式完成,结合模态框和表单交互逻辑。以下是具体实现方法: 1. 创建弹窗组件 新建一个Vue组件文件(如SignContractDi…

vue穿梭框组件实现

vue穿梭框组件实现

实现基础穿梭框组件 在Vue中实现穿梭框组件,可以使用<el-transfer>(Element UI)或手动实现。以下是手动实现的核心逻辑: <template> &…