vue篇-基于session和github-oauth2实现登录注册验证

本文简介

本文讲解前端通过简单的方式实现一个基本的登录注册验证功能。在后端,使用 session 表来存储会话信息,并让前端的 localStorage 存储 sessionId。通过 sessionId 可以在 session 表中获取用户的信息。此外,还利用 session 表实现了 GitHub 的 OAuth2 第三方登录。

基本思路

在本项目中,我们使用 Vue 作为前端框架,通过与后端 API 交互来管理用户的会话状态。

  1. 用户注册和登录:用户在前端输入用户名和密码,通过表单提交到后端进行验证。成功登录后,后端返回一个 sessionId,前端将其存储在localStorage中。
  2. 会话管理:前端在每次请求时会在请求头中附带 sessionId,以便后端能够验证用户的身份。
  3. 第三方登录:用户点击GitHub登录按钮后,前端会重定向到GitHub的授权页面。用户授权后,GitHub重定向回我们的网站,并附带授权码。前端将授权码发送到后端服务器以换取访问令牌。

框架版本

  • Vue 3
  • Pinia (用于状态管理)
  • Vue Router (用于路由管理)
  • Axios (用于 HTTP 请求)
  • tailwind (用于css)
  • element-plus (用于css)

开源地址

主要学习点

路由守卫

路由守卫确保只有经过身份验证的用户才能访问某些页面。

// 添加全局前置守卫
router.beforeEach(async (to, from, next) => {
   
   
    if (to.name == "Home") {
   
   
        const sessionId = ref("");
        const sessionIdFromUrl = to.query.sessionId as string;
        if (sessionIdFromUrl) {
   
   
            sessionId.value = sessionIdFromUrl;
            localStorage.setItem('sessionId', sessionIdFromUrl);
        } else if (localStorage.getItem('sessionId')) {
   
   
            sessionId.value = localStorage.getItem('sessionId') || '';
        }
        if (sessionId.value == '') {
   
   
            // 没有 sessionId,重定向到登录页面
            return next({
   
    name: 'Login' });
        } else {
   
   
            try {
   
   
                // 验证 sessionId 是否有效
                const response = await axios.get('http://localhost:8080/auth/home', {
   
   
                    params: {
   
    sessionId: sessionId.value }
                });
                if (response.data && response.data.data) {
   
   
                    // 如果 username 存在,则 sessionId 有效
                    localStorage.setItem('username', response.data.data);
                    next();
                } else {
   
   
                    // 如果无效,清除 localStorage 并重定向到登录页面
                    localStorage.removeItem('sessionId');
                    next({
   
    name: 'Login' });
                }
            } catch (error) {
   
   
                console.error('验证 sessionId 失败:', error);
                localStorage.removeItem('sessionId');
                next({
   
    name: 'Login' });
            }
        }
    } else {
   
   
        // 如果目标路由是登录页面,直接继续导航
        next();
    }
});

代码设计

Login.vue

<script setup lang="ts">

import {
   
    ref } from 'vue';
import axios from 'axios';
import router from '../routes.ts';

const username = ref('');
const password = ref('');

const handleLogin = async () => {
   
   
  try {
   
   
    const response = await axios.post('http://localhost:8080/auth/login',{
   
   
      username: username
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值