当前位置: 首页 > article >正文

前端登录鉴权全解析:主流方案对比与实现指南

文章目录

    • 一、常见登录鉴权方式概览
      • 1.1 主流方案对比
      • 1.2 技术特性对比
    • 二、Session/Cookie方案
      • 2.1 实现原理
      • 2.2 代码实现
      • 2.3 优缺点分析
    • 三、JWT方案
      • 3.1 实现原理
      • 3.2 代码实现
      • 3.3 优缺点分析
    • 四、OAuth方案
      • 4.1 实现原理
      • 4.2 代码实现
      • 4.3 优缺点分析
    • 五、SSO方案
      • 5.1 实现原理
      • 5.2 代码实现
      • 5.3 优缺点分析
    • 六、安全增强方案
      • 6.1 防御CSRF
      • 6.2 防止重放攻击
    • 七、生产环境最佳实践
      • 7.1 安全配置
      • 7.2 监控与报警

一、常见登录鉴权方式概览

1.1 主流方案对比

45% 35% 15% 5% 鉴权方式使用率 Session/Cookie JWT OAuth 其他

1.2 技术特性对比

方案存储位置安全性扩展性性能适用场景
Session/Cookie服务端传统Web应用
JWT客户端前后端分离
OAuth服务端第三方登录
SSO服务端企业级应用

二、Session/Cookie方案

2.1 实现原理

用户 客户端 服务端 输入凭证 提交登录请求 验证凭证 创建Session 返回Set-Cookie 存储Cookie 后续请求携带Cookie 验证Session 返回资源 用户 客户端 服务端

2.2 代码实现

// 服务端(Express示例)
app.post('/login', (req, res) => {const { username, password } = req.bodyconst user = authenticate(username, password)if (user) {req.session.userId = user.idres.json({ success: true })} else {res.status(401).json({ error: 'Invalid credentials' })}
})app.get('/profile', (req, res) => {if (!req.session.userId) {return res.status(401).json({ error: 'Unauthorized' })}const user = getUserById(req.session.userId)res.json(user)
})

2.3 优缺点分析

优点:

  • 安全性高:敏感信息存储在服务端
  • 易于控制:可随时使Session失效
  • 兼容性好:支持传统Web应用

缺点:

  • 扩展性差:集群环境下需要Session共享
  • 性能开销:每次请求都需要查询Session
  • 跨域限制:Cookie存在SameSite限制

三、JWT方案

3.1 实现原理

用户 客户端 服务端 输入凭证 提交登录请求 验证凭证 生成JWT 返回JWT 存储JWT 后续请求携带JWT 验证JWT 返回资源 用户 客户端 服务端

3.2 代码实现

// JWT生成
function generateToken(user) {return jwt.sign({ userId: user.id },process.env.JWT_SECRET,{ expiresIn: '1h' })
}// 客户端存储
localStorage.setItem('token', token)// 请求拦截
axios.interceptors.request.use(config => {const token = localStorage.getItem('token')if (token) {config.headers.Authorization = `Bearer ${token}`}return config
})// 服务端验证
function authenticateToken(req, res, next) {const authHeader = req.headers['authorization']const token = authHeader && authHeader.split(' ')[1]if (!token) return res.sendStatus(401)jwt.verify(token, process.env.JWT_SECRET, (err, user) => {if (err) return res.sendStatus(403)req.user = usernext()})
}

3.3 优缺点分析

优点:

  • 无状态:服务端无需存储Session
  • 扩展性好:适合分布式系统
  • 性能高:减少数据库查询
  • 跨域支持:不受Cookie限制

缺点:

  • 安全性依赖实现:需妥善管理密钥
  • 无法主动失效:依赖过期时间
  • 信息泄露风险:Payload可解码

四、OAuth方案

4.1 实现原理

用户 客户端 认证服务器 资源服务器 点击第三方登录 重定向到授权页面 显示授权页面 授权登录 返回授权码 用授权码换取Token 返回Access Token 使用Token请求资源 返回资源 用户 客户端 认证服务器 资源服务器

4.2 代码实现

// 客户端实现
function loginWithOAuth(provider) {const authUrl = `${provider.authEndpoint}?client_id=${provider.clientId}&redirect_uri=${provider.redirectUri}&response_type=code&scope=email`window.location.href = authUrl
}// 处理回调
function handleOAuthCallback() {const code = new URLSearchParams(window.location.search).get('code')if (code) {exchangeCodeForToken(code)}
}async function exchangeCodeForToken(code) {const response = await fetch('/api/oauth/token', {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({ code })})const { access_token } = await response.json()localStorage.setItem('oauth_token', access_token)
}

4.3 优缺点分析

优点:

  • 安全性高:用户凭证不暴露给第三方
  • 标准化:主流平台统一实现
  • 权限控制:支持细粒度授权
  • 用户体验:无需注册新账号

缺点:

  • 实现复杂:涉及多个参与方
  • 性能开销:多次跳转和请求
  • 依赖第三方:服务稳定性不可控

五、SSO方案

5.1 实现原理

用户 应用A 应用B 认证中心 访问应用A 重定向到SSO 显示登录页面 登录认证 返回认证令牌 授权访问 访问应用B 检查登录状态 返回认证信息 授权访问 用户 应用A 应用B 认证中心

5.2 代码实现

// 认证中心
app.get('/sso/login', (req, res) => {const { redirect_uri } = req.queryconst token = generateToken()res.redirect(`${redirect_uri}?token=${token}`)
})// 应用A
app.get('/login', (req, res) => {const redirectUri = encodeURIComponent('https://app-a.com/callback')res.redirect(`https://sso.com/login?redirect_uri=${redirectUri}`)
})app.get('/callback', (req, res) => {const { token } = req.queryconst user = verifyToken(token)req.session.user = userres.redirect('/')
})

5.3 优缺点分析

优点:

  • 统一认证:一次登录,多处访问
  • 集中管理:便于权限控制
  • 安全性高:减少密码暴露

缺点:

  • 实现复杂:需要统一认证中心
  • 单点故障:认证中心宕机影响所有系统
  • 性能开销:跨系统认证交互

六、安全增强方案

6.1 防御CSRF

// 服务端生成Token
app.use((req, res, next) => {res.locals.csrfToken = generateCSRFToken()next()
})// 客户端验证
function validateCSRFToken(req) {const clientToken = req.headers['x-csrf-token']const serverToken = req.session.csrfTokenreturn clientToken === serverToken
}

6.2 防止重放攻击

function generateNonce() {return crypto.randomBytes(16).toString('hex')
}function validateNonce(nonce) {if (usedNonces.has(nonce)) {return false}usedNonces.add(nonce)return true
}

七、生产环境最佳实践

7.1 安全配置

// Cookie安全设置
app.use(session({secret: 'your-secret-key',cookie: {httpOnly: true,secure: process.env.NODE_ENV === 'production',sameSite: 'strict',maxAge: 1000 * 60 * 60 * 24 // 1天}
}))

7.2 监控与报警

// 登录失败监控
app.post('/login', (req, res) => {const { username } = req.bodyif (failedAttempts[username] > 5) {sendAlert(`多次登录失败: ${username}`)}
})// 异常登录检测
function detectAnomaly(loginInfo) {const { ip, device, location } = loginInfoif (!previousLoginLocations[ip].includes(location)) {sendAlert(`异常登录: ${ip} from ${location}`)}
}

总结:本文详细讲解了主流登录鉴权方案的实现原理、代码示例和优缺点对比,并提供了安全增强和生产环境最佳实践。
在这里插入图片描述

相关文章:

前端登录鉴权全解析:主流方案对比与实现指南

文章目录 一、常见登录鉴权方式概览1.1 主流方案对比1.2 技术特性对比 二、Session/Cookie方案2.1 实现原理2.2 代码实现2.3 优缺点分析 三、JWT方案3.1 实现原理3.2 代码实现3.3 优缺点分析 四、OAuth方案4.1 实现原理4.2 代码实现4.3 优缺点分析 五、SSO方案5.1 实现原理5.2 …...

【C++】每日一练(链表的中间结点)

本篇博客给大家带来的是用C语言来解答找中间结点! 🐟🐟文章专栏:每日一练 🚀🚀若有问题评论区下讨论,我会及时回答 ❤❤欢迎大家点赞、收藏、分享! 今日思想:不服输的…...

『大模型笔记』什么是MCP?将AI智能体与数据库和API集成

什么是MCP?将AI智能体与数据库和API集成 文章目录 MCP 由多个组件组成,最重要的有以下三个:MCP 体系结构MCP 的实际应用示例为什么要关注 MCP?官方MCP架构图总结如果你正在构建 AI 智能体,可能听说过 MCP(Model Context Protocol,模型上下文协议)。MCP 是一个开源标准…...

使用Redis如何实现分布式锁?(超卖)

分布式锁概念 在多线程环境下,为了保证数据的线程安全,锁保证同一时刻,只有一个可以访问和更新共享数据。在单机系统我们可以使用 synchronized 锁、Lock 锁保证线程安全。 synchronized 锁是 Java 提供的一种内置锁,在单个 JVM …...

【雅思播客07】I‘m in debt.负债

Hey guys! Welcome to my channel, I’m Mavis. Good morning! 欢迎来到我的频道,我是Mavis老师,早上好呀! Today we’re gonna learn a dialogue about recession, a period of temporary economic decline during which trade and indu…...

实现悬浮按钮拖动,兼容h5和微信小程序

h5用js写,微信小程序用 代码里面没有完全实现吸附边缘的功能,需要吸附边缘的话还得自己再完善下(h5的吸附边缘是可以的,小程序的还有点问题) 主要功能是:图片上写文字的悬浮按钮,文字使用的是…...

JavaScript 模块 vs C# 类:封装逻辑的两种哲学

引言 在现代软件开发中,模块化和面向对象设计是代码组织的核心课题。本文通过对比 JavaScript 模块(ES6 Module)与 C# 类(Class)的实现方式,探讨两种语言在封装逻辑时的不同哲学,并给出实际应用…...

Java面向对象编程进阶:深入理解static、单例模式与继承

在面向对象编程(OOP)中,掌握高级特性是提升代码质量和设计能力的关键。本文基于Java语言,深入探讨static关键字、单例设计模式、继承等核心概念,并结合实际应用场景与深度思考,帮助读者构建系统化的知识体系…...

【6】拓扑排序学习笔记

前言 有向无环图和拓扑排序直接关联到中后期的图论建模思想,是很重要的基础知识。这个如果不彻底弄懂,以后图论会很困难。 有向无环图 正如其名,一个边有向,没有环的图,也叫DAG。 DAG图实际运用:描述含…...

珠算之加减法中出现负数情况

在珠算加减法过程中出现负数情况的处理 如果数字 A 小于 B,要求计算 A-B,此时出现了小数减大数的情况,其结果应该是负数。 在平时,计算 A-B 时,如果发现 A 小于 B,则计算时只要计算 B-A,结果记…...

使用Python在Word中生成多种不同类型的图表

目录 工具与环境配置 在 Word 中创建图表的步骤 在Word中创建柱形图 在Word中创建条形图 在Word中创建折线图 在Word中创建饼图 在Word中创建散点图 在Word中创建气泡图 在 Word 文档中插入图表不仅能更直观地呈现数据,还能提升文档的可读性和专业性。常见的…...

pycharm + anaconda + yolo11(ultralytics) 的视频流实时检测,保存推流简单实现

目录 背景pycharm安装配置代码实现创建本地视频配置 和 推流配置视频帧的处理和检测框绘制主要流程遇到的一些问题 背景 首先这个基于完整安装配置了anaconda和yolo11的环境,如果需要配置开始的话,先看下专栏里另一个文章。 这次的目的是实现拉取视频流…...

Netty基础—5.Netty的使用简介

大纲 1.Netty服务端的启动流程 2.服务端IO事件的处理类 3.Netty客户端的启动流程 4.客户端IO事件的处理类 5.启动Netty服务端和客户端的方法说明 6.Netty服务端和客户端使用总结 7.什么是TCP粘包拆包 8.TCP粘包拆包的几种情况 9.TCP粘包拆包的原因 10.粘包问题的解决…...

C++初阶——类和对象(一)

C初阶——类和对象(一) 一、面向过程和面向对象 1.面向过程 面向过程的程序设计(Procedure-Oriented Programming),简称POP,是一种是以程序执行流程为核心的编程范式。它是先分析出解决问题所需要的的步…...

1141. 【贪心算法】排队打水

题目描述 有n&#xff08;n<1000&#xff09;个人在一个水龙头前排队接水&#xff0c;假如每个人接水的时间为Ti&#xff0c; 请编程找出这n个人排队的一种顺序&#xff0c;使得n个人的平均等待时间最小。输入 输入文件共两行&#xff0c;第一行为n&#xff1b; 第二行分别…...

RabbitMQ入门:从安装到高级消息模式

文章目录 一. RabbitMQ概述1.1 同步/异步1.1.1 同步调用1.1.2 异步调用 1.2 消息中间件1.2.1 概念1.2.2 作用1.2.3 常见的消息中间件1.2.4 其他中间件 1.3 RabbitMQ1.3.1 简介1.3.2 特点1.3.3 方式1.3.4 架构1.3.5 运行流程 二. 安装2.1 Docker 安装 RabbitMQ 三. 简单队列&…...

Linux应用:进程的回收

进程的诞生和消亡 程的诞生通常是通过系统调用&#xff08;如fork、exec等&#xff09;来创建新进程。当一个进程完成其任务或者出现错误时&#xff0c;它会进入消亡阶段。进程可以通过exit函数主动结束自身&#xff0c;也可能由于操作系统的调度策略&#xff08;如资源耗尽、…...

如何利用 AI 技术快速定位和修复生产环境问题

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…...

Linux find 命令完全指南

find 是 Linux 系统最强大的文件搜索工具&#xff0c;支持 嵌套遍历、条件筛选、执行动作。以下通过场景分类解析核心用法&#xff0c;涵盖高效搜索、文件管理及高级技巧&#xff1a; 一、基础搜索模式 1. 按文件名搜索&#xff08;精确/模糊匹配&#xff09; <BASH> f…...

市场波动中的风险管理与策略优化

市场波动中的风险管理与策略优化 在市场交易中&#xff0c;价格的波动性为投资者提供了交易机会&#xff0c;但同时也带来了风险。如何在市场不确定性中进行有效的风险管理&#xff0c;并优化交易策略&#xff0c;是每位交易者都需要思考的问题。本文将探讨市场波动的影响因素、…...

(链表)206. 反转链表

给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1]示例 2&#xff1a; 输入&#xff1a;head [1,2] 输出&#xff1a;[2,1]示例 3&#xff1a; 输入&am…...

Jetson Orin NX jupyter lab的安装和使用

主要是为了梳理一下整个过程&#xff0c;其实步骤很简单&#xff0c;但容易出错。 注意&#xff0c;实际只有两个文件需要写入&#xff0c;一个是jupyter_lab_config.py&#xff0c;一个是jupyter.service。 配置文件的名字要写对&#xff0c;如果总是copy网上的代码&#xff0…...

前端npm包- CropperJS

文章目录 一、CropperJS**核心特性****官网与文档****安装与使用**1. **通过 npm/yarn/pnpm 安装**2. **HTML 结构**3. **引入 CSS 和 JS**4. **初始化裁剪器** **相关插件/替代方案****适用场景****注意事项** 总结 一、CropperJS cropperjs 是一个轻量级、功能强大的 图片裁…...

农业建设项目管理系统评测:8款推荐工具优缺点分析

本文主要介绍了以下8款农业建设项目管理系统&#xff1a;1.PingCode&#xff1b; 2. Worktile &#xff1b;3. 建米农业工程项目管理系统&#xff1b;4. 开创云数字农业管理平台&#xff1b; 5. Trimble Ag Software&#xff1b;6.Conservis&#xff1b; 7. Agworld &#xff1…...

linux 命令 tail

tail 是 Linux 中用于查看文件末尾内容的命令&#xff0c;常用于日志监控和大文件快速浏览。以下是其核心用法及常见选项&#xff1a; 基本语法 tail [选项] 文件名 常用选项 显示末尾行数 -n <行数> 或 --lines<行数> 指定显示文件的最后若干行&#xff08;…...

测试开发 - 正浩创新 - 一面面经(已OC)

自我介绍 实习过程中&#xff0c;有遇到过什么问题&#xff0c;是如何解决的 实习成果中的数据指标变化&#xff0c;人力消耗一直在递减&#xff0c;是什么原因 实习工作有很多模块&#xff0c;那一块工作对你的提升或者收获是比较大的 讲一下&#xff0c;简历中所罗列的几…...

实验8 搜索技术

实验8 搜索技术 一、实验目的 &#xff08;1&#xff09;掌握搜索技术的相关理论&#xff0c;能根据实际情况选取合适的搜索方法&#xff1b; &#xff08;2&#xff09;进一步熟悉盲目搜索技术&#xff0c;掌握其在搜索过程中的优缺点&#xff1b; &#xff08;3&#xff09;…...

VSTO(C#)Excel开发9:处理格式和字体

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码指引&#xff1a;github源…...

LinkedList底层结构和源码分析(JDK1.8)

参考视频&#xff1a;韩顺平Java集合 特点 LinkedList 底层实现了 双向链表 和 双端队列 的特点。可以添加任意元素&#xff08;元素可以重复&#xff09;&#xff0c;包括 null。线程不安全&#xff0c;没有实现同步。 LinkedList 底层结构 LinkedList 底层维护了一个双向链…...

数字内容体验的技术支柱是什么?

数据分析引擎构建基础 数字内容体验的技术底座始于对海量用户行为数据的深度解析。作为技术体系的根基&#xff0c;数据分析引擎通过实时采集、清洗与结构化处理&#xff0c;将分散的点击轨迹、停留时长及交互偏好转化为可操作的洞察。其核心能力体现在三方面&#xff1a;一是…...